. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Registry; use Fisharebest\Webtrees\Validator; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use function preg_replace; use function redirect; use function trim; /** * Edit the raw GEDCOM of a fact. */ class EditRawFactAction implements RequestHandlerInterface { /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function handle(ServerRequestInterface $request): ResponseInterface { $tree = Validator::attributes($request)->tree(); $xref = Validator::attributes($request)->isXref()->string('xref'); $record = Registry::gedcomRecordFactory()->make($xref, $tree); $record = Auth::checkRecordAccess($record, true); $fact_id = Validator::attributes($request)->string('fact_id'); $params = (array) $request->getParsedBody(); $gedcom = $params['gedcom']; // Cleanup the client’s bad editing? $gedcom = preg_replace('/[\r\n]+/', "\n", $gedcom); // Empty lines $gedcom = trim($gedcom); // Leading/trailing spaces $record = Auth::checkRecordAccess($record, true); foreach ($record->facts([], false, null, true) as $fact) { if ($fact->id() === $fact_id && $fact->canEdit()) { $record->updateFact($fact_id, $gedcom, false); break; } } $base_url = Validator::attributes($request)->string('base_url'); $url = Validator::parsedBody($request)->isLocalUrl($base_url)->string('url', $record->url()); return redirect($url); } }