xref: /webtrees/app/Http/RequestHandlers/AddSpouseToIndividualAction.php (revision b55cbc6b43247e8b2ad14af6f6d24dc6747195ff)
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