xref: /webtrees/app/Http/RequestHandlers/AddSpouseToFamilyAction.php (revision 6b9cb339562c8aa4681c7eff2bf3bdf401cc9edd)
17c7d1e03SGreg Roach<?php
27c7d1e03SGreg Roach
37c7d1e03SGreg Roach/**
47c7d1e03SGreg Roach * webtrees: online genealogy
57c7d1e03SGreg Roach * Copyright (C) 2020 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
157c7d1e03SGreg Roach * along with this program. If not, see <http://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;
237c7d1e03SGreg Roachuse Fisharebest\Webtrees\Fact;
24*6b9cb339SGreg Roachuse Fisharebest\Webtrees\Registry;
257c7d1e03SGreg Roachuse Fisharebest\Webtrees\Services\GedcomEditService;
267c7d1e03SGreg Roachuse Fisharebest\Webtrees\Tree;
277c7d1e03SGreg Roachuse Psr\Http\Message\ResponseInterface;
287c7d1e03SGreg Roachuse Psr\Http\Message\ServerRequestInterface;
297c7d1e03SGreg Roachuse Psr\Http\Server\RequestHandlerInterface;
307c7d1e03SGreg Roach
317c7d1e03SGreg Roachuse function assert;
327c7d1e03SGreg Roachuse function preg_match_all;
337c7d1e03SGreg Roachuse function redirect;
347c7d1e03SGreg Roachuse function trim;
357c7d1e03SGreg Roach
367c7d1e03SGreg Roach/**
377c7d1e03SGreg Roach * Add a new spouse to a family.
387c7d1e03SGreg Roach */
397c7d1e03SGreg Roachclass AddSpouseToFamilyAction implements RequestHandlerInterface
407c7d1e03SGreg Roach{
417c7d1e03SGreg Roach    /** @var GedcomEditService */
427c7d1e03SGreg Roach    private $gedcom_edit_service;
437c7d1e03SGreg Roach
447c7d1e03SGreg Roach    /**
457c7d1e03SGreg Roach     * AddChildToFamilyAction constructor.
467c7d1e03SGreg Roach     *
477c7d1e03SGreg Roach     * @param GedcomEditService $gedcom_edit_service
487c7d1e03SGreg Roach     */
497c7d1e03SGreg Roach    public function __construct(GedcomEditService $gedcom_edit_service)
507c7d1e03SGreg Roach    {
517c7d1e03SGreg Roach        $this->gedcom_edit_service = $gedcom_edit_service;
527c7d1e03SGreg Roach    }
537c7d1e03SGreg Roach
547c7d1e03SGreg Roach    /**
557c7d1e03SGreg Roach     * @param ServerRequestInterface $request
567c7d1e03SGreg Roach     *
577c7d1e03SGreg Roach     * @return ResponseInterface
587c7d1e03SGreg Roach     */
597c7d1e03SGreg Roach    public function handle(ServerRequestInterface $request): ResponseInterface
607c7d1e03SGreg Roach    {
617c7d1e03SGreg Roach        $tree = $request->getAttribute('tree');
627c7d1e03SGreg Roach        assert($tree instanceof Tree);
637c7d1e03SGreg Roach
647c7d1e03SGreg Roach        $xref   = $request->getQueryParams()['xref'];
65*6b9cb339SGreg Roach        $family = Registry::familyFactory()->make($xref, $tree);
667c7d1e03SGreg Roach        $family = Auth::checkFamilyAccess($family, true);
677c7d1e03SGreg Roach
687c7d1e03SGreg Roach        $params = (array) $request->getParsedBody();
697c7d1e03SGreg Roach
707c7d1e03SGreg Roach        $this->gedcom_edit_service->glevels = $params['glevels'] ?? [];
717c7d1e03SGreg Roach        $this->gedcom_edit_service->tag     = $params['tag'] ?? [];
727c7d1e03SGreg Roach        $this->gedcom_edit_service->text    = $params['text'] ?? [];
737c7d1e03SGreg Roach        $this->gedcom_edit_service->islink  = $params['islink'] ?? [];
747c7d1e03SGreg Roach
757c7d1e03SGreg Roach        // Create the new spouse
767c7d1e03SGreg Roach        $this->gedcom_edit_service->splitSource(); // separate SOUR record from the rest
777c7d1e03SGreg Roach
787c7d1e03SGreg Roach        $gedrec = '0 @@ INDI';
797c7d1e03SGreg Roach        $gedrec .= $this->gedcom_edit_service->addNewName($request, $tree);
807c7d1e03SGreg Roach        $gedrec .= $this->gedcom_edit_service->addNewSex($request);
817c7d1e03SGreg Roach        if (preg_match_all('/([A-Z0-9_]+)/', $tree->getPreference('QUICK_REQUIRED_FACTS'), $matches)) {
827c7d1e03SGreg Roach            foreach ($matches[1] as $match) {
837c7d1e03SGreg Roach                $gedrec .= $this->gedcom_edit_service->addNewFact($request, $tree, $match);
847c7d1e03SGreg Roach            }
857c7d1e03SGreg Roach        }
867c7d1e03SGreg Roach
877c7d1e03SGreg Roach        if ($params['SOUR_INDI'] ?? false) {
887c7d1e03SGreg Roach            $gedrec = $this->gedcom_edit_service->handleUpdates($gedrec);
897c7d1e03SGreg Roach        } else {
907c7d1e03SGreg Roach            $gedrec = $this->gedcom_edit_service->updateRest($gedrec);
917c7d1e03SGreg Roach        }
927c7d1e03SGreg Roach        $gedrec .= "\n1 FAMS @" . $family->xref() . '@';
937c7d1e03SGreg Roach        $spouse = $tree->createIndividual($gedrec);
947c7d1e03SGreg Roach
957c7d1e03SGreg Roach        // Update the existing family - add marriage, etc
967c7d1e03SGreg Roach        if ($family->facts(['HUSB'])->first() instanceof Fact) {
977c7d1e03SGreg Roach            $family->createFact('1 WIFE @' . $spouse->xref() . '@', true);
987c7d1e03SGreg Roach        } else {
997c7d1e03SGreg Roach            $family->createFact('1 HUSB @' . $spouse->xref() . '@', true);
1007c7d1e03SGreg Roach        }
1017c7d1e03SGreg Roach        $famrec = '';
1027c7d1e03SGreg Roach        if (preg_match_all('/([A-Z0-9_]+)/', $tree->getPreference('QUICK_REQUIRED_FAMFACTS'), $matches)) {
1037c7d1e03SGreg Roach            foreach ($matches[1] as $match) {
1047c7d1e03SGreg Roach                $famrec .= $this->gedcom_edit_service->addNewFact($request, $tree, $match);
1057c7d1e03SGreg Roach            }
1067c7d1e03SGreg Roach        }
1077c7d1e03SGreg Roach        if ($params['SOUR_FAM'] ?? false) {
1087c7d1e03SGreg Roach            $famrec = $this->gedcom_edit_service->handleUpdates($famrec);
1097c7d1e03SGreg Roach        } else {
1107c7d1e03SGreg Roach            $famrec = $this->gedcom_edit_service->updateRest($famrec);
1117c7d1e03SGreg Roach        }
1127c7d1e03SGreg Roach        $family->createFact(trim($famrec), true); // trim leading \n
1137c7d1e03SGreg Roach
1147c7d1e03SGreg Roach        if (($params['goto'] ?? '') === 'new') {
1157c7d1e03SGreg Roach            return redirect($spouse->url());
1167c7d1e03SGreg Roach        }
1177c7d1e03SGreg Roach
1187c7d1e03SGreg Roach        return redirect($family->url());
1197c7d1e03SGreg Roach    }
1207c7d1e03SGreg Roach}
121