17c7d1e03SGreg Roach<?php 27c7d1e03SGreg Roach 37c7d1e03SGreg Roach/** 47c7d1e03SGreg Roach * webtrees: online genealogy 589f7189bSGreg Roach * Copyright (C) 2021 webtrees development team 67c7d1e03SGreg Roach * This program is free software: you can redistribute it and/or modify 77c7d1e03SGreg Roach * it under the terms of the GNU General Public License as published by 87c7d1e03SGreg Roach * the Free Software Foundation, either version 3 of the License, or 97c7d1e03SGreg Roach * (at your option) any later version. 107c7d1e03SGreg Roach * This program is distributed in the hope that it will be useful, 117c7d1e03SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 127c7d1e03SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 137c7d1e03SGreg Roach * GNU General Public License for more details. 147c7d1e03SGreg Roach * You should have received a copy of the GNU General Public License 1589f7189bSGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 167c7d1e03SGreg Roach */ 177c7d1e03SGreg Roach 187c7d1e03SGreg Roachdeclare(strict_types=1); 197c7d1e03SGreg Roach 207c7d1e03SGreg Roachnamespace Fisharebest\Webtrees\Http\RequestHandlers; 217c7d1e03SGreg Roach 227c7d1e03SGreg Roachuse Fisharebest\Webtrees\Auth; 236b9cb339SGreg Roachuse Fisharebest\Webtrees\Registry; 247c7d1e03SGreg Roachuse Fisharebest\Webtrees\Services\GedcomEditService; 258d9c2b68SGreg Roachuse Fisharebest\Webtrees\Validator; 267c7d1e03SGreg Roachuse Psr\Http\Message\ResponseInterface; 277c7d1e03SGreg Roachuse Psr\Http\Message\ServerRequestInterface; 287c7d1e03SGreg Roachuse Psr\Http\Server\RequestHandlerInterface; 297c7d1e03SGreg Roach 307c7d1e03SGreg Roachuse function redirect; 317c7d1e03SGreg Roach 327c7d1e03SGreg Roach/** 337c7d1e03SGreg Roach * Add a new spouse to an individual, creating a new family. 347c7d1e03SGreg Roach */ 357c7d1e03SGreg Roachclass AddSpouseToIndividualAction implements RequestHandlerInterface 367c7d1e03SGreg Roach{ 37c4943cffSGreg Roach private GedcomEditService $gedcom_edit_service; 387c7d1e03SGreg Roach 397c7d1e03SGreg Roach /** 407c7d1e03SGreg Roach * AddChildToFamilyAction constructor. 417c7d1e03SGreg Roach * 427c7d1e03SGreg Roach * @param GedcomEditService $gedcom_edit_service 437c7d1e03SGreg Roach */ 447c7d1e03SGreg Roach public function __construct(GedcomEditService $gedcom_edit_service) 457c7d1e03SGreg Roach { 467c7d1e03SGreg Roach $this->gedcom_edit_service = $gedcom_edit_service; 477c7d1e03SGreg Roach } 487c7d1e03SGreg Roach 497c7d1e03SGreg Roach /** 507c7d1e03SGreg Roach * @param ServerRequestInterface $request 517c7d1e03SGreg Roach * 527c7d1e03SGreg Roach * @return ResponseInterface 537c7d1e03SGreg Roach */ 547c7d1e03SGreg Roach public function handle(ServerRequestInterface $request): ResponseInterface 557c7d1e03SGreg Roach { 56*b55cbc6bSGreg Roach $tree = Validator::attributes($request)->tree(); 57*b55cbc6bSGreg Roach $xref = Validator::attributes($request)->isXref()->string('xref'); 58efd4768bSGreg Roach $params = (array) $request->getParsedBody(); 596b9cb339SGreg Roach $individual = Registry::individualFactory()->make($xref, $tree); 607c7d1e03SGreg Roach $individual = Auth::checkIndividualAccess($individual, true); 617c7d1e03SGreg Roach 620c71b2e5SGreg Roach // Create the new spouse 63efd4768bSGreg Roach $levels = $params['ilevels'] ?? []; 64efd4768bSGreg Roach $tags = $params['itags'] ?? []; 65efd4768bSGreg Roach $values = $params['ivalues'] ?? []; 66efd4768bSGreg Roach $gedcom = $this->gedcom_edit_service->editLinesToGedcom('INDI', $levels, $tags, $values); 67efd4768bSGreg Roach $spouse = $tree->createIndividual("0 @@ INDI\n" . $gedcom); 68efd4768bSGreg Roach 690c71b2e5SGreg Roach // Create the new family 700c71b2e5SGreg Roach $levels = $params['flevels'] ?? []; 710c71b2e5SGreg Roach $tags = $params['ftags'] ?? []; 720c71b2e5SGreg Roach $values = $params['fvalues'] ?? []; 730c71b2e5SGreg Roach $gedcom = $this->gedcom_edit_service->editLinesToGedcom('FAM', $levels, $tags, $values); 74efd4768bSGreg Roach $i_link = "\n1 " . ($individual->sex() === 'F' ? 'WIFE' : 'HUSB') . ' @' . $individual->xref() . '@'; 75efd4768bSGreg Roach $s_link = "\n1 " . ($individual->sex() !== 'F' ? 'WIFE' : 'HUSB') . ' @' . $spouse->xref() . '@'; 760c71b2e5SGreg Roach $family = $tree->createFamily("0 @@ FAM\n" . $gedcom . $i_link . $s_link); 777c7d1e03SGreg Roach 78efd4768bSGreg Roach // Link the individual to the family 79efd4768bSGreg Roach $individual->createFact('1 FAMS @' . $family->xref() . '@', false); 807c7d1e03SGreg Roach 81efd4768bSGreg Roach // Link the spouse to the family 82efd4768bSGreg Roach $spouse->createFact('1 FAMS @' . $family->xref() . '@', false); 83efd4768bSGreg Roach 84*b55cbc6bSGreg Roach $base_url = Validator::attributes($request)->string('base_url'); 85*b55cbc6bSGreg Roach $url = Validator::parsedBody($request)->isLocalUrl($base_url)->optionalString('url') ?? $spouse->url(); 86551ad4afSGreg Roach 87551ad4afSGreg Roach return redirect($url); 887c7d1e03SGreg Roach } 897c7d1e03SGreg Roach} 90