13b3db8adSGreg Roach<?php 23b3db8adSGreg Roach 33b3db8adSGreg Roach/** 43b3db8adSGreg Roach * webtrees: online genealogy 589f7189bSGreg 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 1589f7189bSGreg 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; 25*4c3814d0SGreg Roachuse Fisharebest\Webtrees\Note; 266b9cb339SGreg Roachuse Fisharebest\Webtrees\Registry; 273b3db8adSGreg Roachuse Fisharebest\Webtrees\Tree; 283b3db8adSGreg Roachuse Psr\Http\Message\ResponseInterface; 293b3db8adSGreg Roachuse Psr\Http\Message\ServerRequestInterface; 303b3db8adSGreg Roachuse Psr\Http\Server\RequestHandlerInterface; 313b3db8adSGreg Roach 323b3db8adSGreg Roachuse function assert; 33ce7d84caSGreg Roachuse function explode; 34ddeb3354SGreg Roachuse function is_string; 353b3db8adSGreg Roach 363b3db8adSGreg Roach/** 373b3db8adSGreg Roach * Edit the raw GEDCOM of a record. 383b3db8adSGreg Roach */ 393b3db8adSGreg Roachclass EditRawRecordAction implements RequestHandlerInterface 403b3db8adSGreg Roach{ 413b3db8adSGreg Roach /** 423b3db8adSGreg Roach * @param ServerRequestInterface $request 433b3db8adSGreg Roach * 443b3db8adSGreg Roach * @return ResponseInterface 453b3db8adSGreg Roach */ 463b3db8adSGreg Roach public function handle(ServerRequestInterface $request): ResponseInterface 473b3db8adSGreg Roach { 483b3db8adSGreg Roach $tree = $request->getAttribute('tree'); 493b3db8adSGreg Roach assert($tree instanceof Tree); 503b3db8adSGreg Roach 512917771cSGreg Roach $xref = $request->getAttribute('xref'); 52ddeb3354SGreg Roach assert(is_string($xref)); 533b3db8adSGreg Roach 546b9cb339SGreg Roach $record = Registry::gedcomRecordFactory()->make($xref, $tree); 55ddeb3354SGreg Roach $record = Auth::checkRecordAccess($record, true); 563b3db8adSGreg Roach 57b46c87bdSGreg Roach $params = (array) $request->getParsedBody(); 58b46c87bdSGreg Roach 59*4c3814d0SGreg Roach $level0 = $params['level0']; 60b46c87bdSGreg Roach $facts = $params['fact'] ?? []; 61b46c87bdSGreg Roach $fact_ids = $params['fact_id'] ?? []; 622917771cSGreg Roach 63ce7d84caSGreg Roach // Generate the level-0 line for the record. 6402467d32SGreg Roach switch ($record->tag()) { 65ce7d84caSGreg Roach case GedcomRecord::RECORD_TYPE: 66ce7d84caSGreg Roach // Unknown type? - copy the existing data. 67ce7d84caSGreg Roach $gedcom = explode("\n", $record->gedcom(), 2)[0]; 68ce7d84caSGreg Roach break; 69ce7d84caSGreg Roach case Header::RECORD_TYPE: 70ce7d84caSGreg Roach $gedcom = '0 HEAD'; 71ce7d84caSGreg Roach break; 72ce7d84caSGreg Roach default: 7302467d32SGreg Roach $gedcom = '0 @' . $xref . '@ ' . $record->tag(); 74ce7d84caSGreg Roach } 753b3db8adSGreg Roach 76*4c3814d0SGreg Roach if ($level0 !== '') { 77*4c3814d0SGreg Roach $gedcom = $level0; 78*4c3814d0SGreg Roach } 79*4c3814d0SGreg Roach 803b3db8adSGreg Roach // Retain any private facts 8119aed3a1SGreg Roach foreach ($record->facts([], false, Auth::PRIV_HIDE, true) as $fact) { 8219aed3a1SGreg Roach if (!in_array($fact->id(), $fact_ids, true)) { 833b3db8adSGreg Roach $gedcom .= "\n" . $fact->gedcom(); 843b3db8adSGreg Roach } 853b3db8adSGreg Roach } 863b3db8adSGreg Roach // Append the updated facts 873b3db8adSGreg Roach foreach ($facts as $fact) { 883b3db8adSGreg Roach $gedcom .= "\n" . $fact; 893b3db8adSGreg Roach } 903b3db8adSGreg Roach 913b3db8adSGreg Roach // Empty lines and MSDOS line endings. 923b3db8adSGreg Roach $gedcom = preg_replace('/[\r\n]+/', "\n", $gedcom); 933b3db8adSGreg Roach $gedcom = trim($gedcom); 943b3db8adSGreg Roach 953b3db8adSGreg Roach $record->updateRecord($gedcom, false); 963b3db8adSGreg Roach 973b3db8adSGreg Roach return redirect($record->url()); 983b3db8adSGreg Roach } 993b3db8adSGreg Roach} 100