1<?php 2 3/** 4 * webtrees: online genealogy 5 * Copyright (C) 2019 webtrees development team 6 * This program is free software: you can redistribute it and/or modify 7 * it under the terms of the GNU General Public License as published by 8 * the Free Software Foundation, either version 3 of the License, or 9 * (at your option) any later version. 10 * This program is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU General Public License for more details. 14 * You should have received a copy of the GNU General Public License 15 * along with this program. If not, see <http://www.gnu.org/licenses/>. 16 */ 17 18declare(strict_types=1); 19 20namespace Fisharebest\Webtrees\Http\RequestHandlers; 21 22use Fisharebest\Webtrees\I18N; 23use Fisharebest\Webtrees\Tree; 24use Psr\Http\Message\ResponseInterface; 25use Psr\Http\Message\ServerRequestInterface; 26use Psr\Http\Server\RequestHandlerInterface; 27 28use function assert; 29 30/** 31 * Process a form to create a new submitter. 32 */ 33class CreateSubmitterAction implements RequestHandlerInterface 34{ 35 /** 36 * @param ServerRequestInterface $request 37 * 38 * @return ResponseInterface 39 */ 40 public function handle(ServerRequestInterface $request): ResponseInterface 41 { 42 $tree = $request->getAttribute('tree'); 43 assert($tree instanceof Tree); 44 45 $params = $request->getParsedBody(); 46 $name = $params['submitter_name']; 47 $address = $params['submitter_address']; 48 $privacy_restriction = $params['privacy-restriction']; 49 $edit_restriction = $params['edit-restriction']; 50 51 // Fix whitespace 52 $name = trim(preg_replace('/\s+/', ' ', $name)); 53 54 // Convert line endings to GEDDCOM continuations 55 $address = str_replace([ 56 "\r\n", 57 "\r", 58 "\n", 59 ], "\n1 CONT ", $address); 60 61 $gedcom = "0 @@ SUBM\n1 NAME " . $name; 62 63 if ($address !== '') { 64 $gedcom .= "\n1 ADDR " . $address; 65 } 66 67 if (in_array($privacy_restriction, ['none', 'privacy', 'confidential'], true)) { 68 $gedcom .= "\n1 RESN " . $privacy_restriction; 69 } 70 71 if ($edit_restriction === 'locked') { 72 $gedcom .= "\n1 RESN " . $edit_restriction; 73 } 74 75 $record = $tree->createRecord($gedcom); 76 77 return response([ 78 'id' => $record->xref(), 79 'text' => view('selects/submitter', [ 80 'submitter' => $record, 81 ]), 82 'html' => view('modals/record-created', [ 83 'title' => I18N::translate('The submitter has been created'), 84 'name' => $record->fullName(), 85 'url' => $record->url(), 86 ]), 87 ]); 88 } 89} 90