13b3db8adSGreg Roach<?php 23b3db8adSGreg Roach 33b3db8adSGreg Roach/** 43b3db8adSGreg Roach * webtrees: online genealogy 5*89f7189bSGreg Roach * Copyright (C) 2021 webtrees development team 63b3db8adSGreg Roach * This program is free software: you can redistribute it and/or modify 73b3db8adSGreg Roach * it under the terms of the GNU General Public License as published by 83b3db8adSGreg Roach * the Free Software Foundation, either version 3 of the License, or 93b3db8adSGreg Roach * (at your option) any later version. 103b3db8adSGreg Roach * This program is distributed in the hope that it will be useful, 113b3db8adSGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 123b3db8adSGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 133b3db8adSGreg Roach * GNU General Public License for more details. 143b3db8adSGreg Roach * You should have received a copy of the GNU General Public License 15*89f7189bSGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 163b3db8adSGreg Roach */ 173b3db8adSGreg Roach 183b3db8adSGreg Roachdeclare(strict_types=1); 193b3db8adSGreg Roach 203b3db8adSGreg Roachnamespace Fisharebest\Webtrees\Http\RequestHandlers; 213b3db8adSGreg Roach 223b3db8adSGreg Roachuse Fisharebest\Webtrees\Auth; 233b3db8adSGreg Roachuse Fisharebest\Webtrees\GedcomRecord; 24ce7d84caSGreg Roachuse Fisharebest\Webtrees\Header; 256b9cb339SGreg Roachuse Fisharebest\Webtrees\Registry; 263b3db8adSGreg Roachuse Fisharebest\Webtrees\Tree; 273b3db8adSGreg Roachuse Psr\Http\Message\ResponseInterface; 283b3db8adSGreg Roachuse Psr\Http\Message\ServerRequestInterface; 293b3db8adSGreg Roachuse Psr\Http\Server\RequestHandlerInterface; 303b3db8adSGreg Roach 313b3db8adSGreg Roachuse function assert; 32ce7d84caSGreg Roachuse function explode; 33ddeb3354SGreg Roachuse function is_string; 343b3db8adSGreg Roach 353b3db8adSGreg Roach/** 363b3db8adSGreg Roach * Edit the raw GEDCOM of a record. 373b3db8adSGreg Roach */ 383b3db8adSGreg Roachclass EditRawRecordAction implements RequestHandlerInterface 393b3db8adSGreg Roach{ 403b3db8adSGreg Roach /** 413b3db8adSGreg Roach * @param ServerRequestInterface $request 423b3db8adSGreg Roach * 433b3db8adSGreg Roach * @return ResponseInterface 443b3db8adSGreg Roach */ 453b3db8adSGreg Roach public function handle(ServerRequestInterface $request): ResponseInterface 463b3db8adSGreg Roach { 473b3db8adSGreg Roach $tree = $request->getAttribute('tree'); 483b3db8adSGreg Roach assert($tree instanceof Tree); 493b3db8adSGreg Roach 502917771cSGreg Roach $xref = $request->getAttribute('xref'); 51ddeb3354SGreg Roach assert(is_string($xref)); 523b3db8adSGreg Roach 536b9cb339SGreg Roach $record = Registry::gedcomRecordFactory()->make($xref, $tree); 54ddeb3354SGreg Roach $record = Auth::checkRecordAccess($record, true); 553b3db8adSGreg Roach 56b46c87bdSGreg Roach $params = (array) $request->getParsedBody(); 57b46c87bdSGreg Roach 58b46c87bdSGreg Roach $facts = $params['fact'] ?? []; 59b46c87bdSGreg Roach $fact_ids = $params['fact_id'] ?? []; 602917771cSGreg Roach 61ce7d84caSGreg Roach // Generate the level-0 line for the record. 6202467d32SGreg Roach switch ($record->tag()) { 63ce7d84caSGreg Roach case GedcomRecord::RECORD_TYPE: 64ce7d84caSGreg Roach // Unknown type? - copy the existing data. 65ce7d84caSGreg Roach $gedcom = explode("\n", $record->gedcom(), 2)[0]; 66ce7d84caSGreg Roach break; 67ce7d84caSGreg Roach case Header::RECORD_TYPE: 68ce7d84caSGreg Roach $gedcom = '0 HEAD'; 69ce7d84caSGreg Roach break; 70ce7d84caSGreg Roach default: 7102467d32SGreg Roach $gedcom = '0 @' . $xref . '@ ' . $record->tag(); 72ce7d84caSGreg Roach } 733b3db8adSGreg Roach 743b3db8adSGreg Roach // Retain any private facts 7519aed3a1SGreg Roach foreach ($record->facts([], false, Auth::PRIV_HIDE, true) as $fact) { 7619aed3a1SGreg Roach if (!in_array($fact->id(), $fact_ids, true)) { 773b3db8adSGreg Roach $gedcom .= "\n" . $fact->gedcom(); 783b3db8adSGreg Roach } 793b3db8adSGreg Roach } 803b3db8adSGreg Roach // Append the updated facts 813b3db8adSGreg Roach foreach ($facts as $fact) { 823b3db8adSGreg Roach $gedcom .= "\n" . $fact; 833b3db8adSGreg Roach } 843b3db8adSGreg Roach 853b3db8adSGreg Roach // Empty lines and MSDOS line endings. 863b3db8adSGreg Roach $gedcom = preg_replace('/[\r\n]+/', "\n", $gedcom); 873b3db8adSGreg Roach $gedcom = trim($gedcom); 883b3db8adSGreg Roach 893b3db8adSGreg Roach $record->updateRecord($gedcom, false); 903b3db8adSGreg Roach 913b3db8adSGreg Roach return redirect($record->url()); 923b3db8adSGreg Roach } 933b3db8adSGreg Roach} 94