11f3fb95cSGreg Roach<?php 2*3976b470SGreg Roach 31f3fb95cSGreg Roach/** 41f3fb95cSGreg Roach * webtrees: online genealogy 58fcd0d32SGreg Roach * Copyright (C) 2019 webtrees development team 61f3fb95cSGreg Roach * This program is free software: you can redistribute it and/or modify 71f3fb95cSGreg Roach * it under the terms of the GNU General Public License as published by 81f3fb95cSGreg Roach * the Free Software Foundation, either version 3 of the License, or 91f3fb95cSGreg Roach * (at your option) any later version. 101f3fb95cSGreg Roach * This program is distributed in the hope that it will be useful, 111f3fb95cSGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 121f3fb95cSGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 131f3fb95cSGreg Roach * GNU General Public License for more details. 141f3fb95cSGreg Roach * You should have received a copy of the GNU General Public License 151f3fb95cSGreg Roach * along with this program. If not, see <http://www.gnu.org/licenses/>. 161f3fb95cSGreg Roach */ 178b67c11aSGreg Roach 1878f07ab5SGreg Roachdeclare(strict_types=1); 191f3fb95cSGreg Roach 206ccdf4f0SGreg Roachuse Fig\Http\Message\StatusCodeInterface; 218b67c11aSGreg Roachuse Fisharebest\Webtrees\Application; 226ccdf4f0SGreg Roachuse Fisharebest\Webtrees\Html; 236ccdf4f0SGreg Roachuse Fisharebest\Webtrees\Session; 248898179dSGreg Roachuse Fisharebest\Webtrees\View as WebtreesView; 2552bcc402SGreg Roachuse Fisharebest\Webtrees\Webtrees; 266ccdf4f0SGreg Roachuse Psr\Http\Message\ResponseFactoryInterface; 276ccdf4f0SGreg Roachuse Psr\Http\Message\ResponseInterface; 289b93b7c3SGreg Roachuse Psr\Http\Message\ServerRequestInterface; 296ccdf4f0SGreg Roachuse Psr\Http\Message\StreamFactoryInterface; 308b67c11aSGreg Roach 318b67c11aSGreg Roach/** 328b67c11aSGreg Roach * Get the IoC container, or fetch something from it. 338b67c11aSGreg Roach * 348b67c11aSGreg Roach * @param string|null $abstract 358b67c11aSGreg Roach * 36cab242e7SGreg Roach * @return mixed 378b67c11aSGreg Roach */ 388b67c11aSGreg Roachfunction app(string $abstract = null) 398b67c11aSGreg Roach{ 408b67c11aSGreg Roach if ($abstract === null) { 418b67c11aSGreg Roach return Application::getInstance(); 428b67c11aSGreg Roach } 43e364afe4SGreg Roach 44e364afe4SGreg Roach return Application::getInstance()->make($abstract); 458b67c11aSGreg Roach} 468b67c11aSGreg Roach 471f3fb95cSGreg Roach/** 4852bcc402SGreg Roach * Generate a URL to an asset file in the public folder. 4952bcc402SGreg Roach * Add a version parameter for cache-busting. 5052bcc402SGreg Roach * 5152bcc402SGreg Roach * @param string $path 5252bcc402SGreg Roach * 5352bcc402SGreg Roach * @return string 5452bcc402SGreg Roach */ 5552bcc402SGreg Roachfunction asset(string $path): string 5652bcc402SGreg Roach{ 5775e7614aSGreg Roach if (substr($path, -1) === '/') { 5875e7614aSGreg Roach $version = ''; 5975e7614aSGreg Roach } elseif (Webtrees::STABILITY === '') { 6075e7614aSGreg Roach $version = '?v=' . Webtrees::VERSION; 6152bcc402SGreg Roach } else { 6275e7614aSGreg Roach $version = '?v=' . filemtime(Webtrees::ROOT_DIR . 'public/' . $path); 6352bcc402SGreg Roach } 6452bcc402SGreg Roach 6575e7614aSGreg Roach return 'public/' . $path . $version; 6652bcc402SGreg Roach} 6752bcc402SGreg Roach 6852bcc402SGreg Roach/** 69f97c7170SGreg Roach * Generate a CSRF token form field. 70f97c7170SGreg Roach * 71f97c7170SGreg Roach * @return string 72f97c7170SGreg Roach */ 73c1010edaSGreg Roachfunction csrf_field() 74c1010edaSGreg Roach{ 756ccdf4f0SGreg Roach return '<input type="hidden" name="csrf" value="' . e(Session::getCsrfToken()) . '">'; 76f97c7170SGreg Roach} 77f97c7170SGreg Roach 78f97c7170SGreg Roach/** 798655ee66SGreg Roach * Get the CSRF token value. 808655ee66SGreg Roach * 818655ee66SGreg Roach * @return string 828655ee66SGreg Roach */ 83c1010edaSGreg Roachfunction csrf_token() 84c1010edaSGreg Roach{ 856ccdf4f0SGreg Roach return Session::getCsrfToken(); 866ccdf4f0SGreg Roach} 876ccdf4f0SGreg Roach 886ccdf4f0SGreg Roach/** 896ccdf4f0SGreg Roach * @param string $url 906ccdf4f0SGreg Roach * @param int $code 916ccdf4f0SGreg Roach * 926ccdf4f0SGreg Roach * @return ResponseInterface 936ccdf4f0SGreg Roach */ 946ccdf4f0SGreg Roachfunction redirect(string $url, $code = StatusCodeInterface::STATUS_FOUND): ResponseInterface 956ccdf4f0SGreg Roach{ 966ccdf4f0SGreg Roach /** @var ResponseFactoryInterface $response_factory */ 976ccdf4f0SGreg Roach $response_factory = app(ResponseFactoryInterface::class); 986ccdf4f0SGreg Roach 996ccdf4f0SGreg Roach return $response_factory 1006ccdf4f0SGreg Roach ->createResponse($code) 1016ccdf4f0SGreg Roach ->withHeader('Location', $url); 1026ccdf4f0SGreg Roach} 1036ccdf4f0SGreg Roach 1046ccdf4f0SGreg Roach/** 1056ccdf4f0SGreg Roach * Create a response. 1066ccdf4f0SGreg Roach * 1076ccdf4f0SGreg Roach * @param mixed $content 1086ccdf4f0SGreg Roach * @param int $code 1096ccdf4f0SGreg Roach * @param string[] $headers 1106ccdf4f0SGreg Roach * 1116ccdf4f0SGreg Roach * @return ResponseInterface 1126ccdf4f0SGreg Roach */ 1136ccdf4f0SGreg Roachfunction response($content = '', $code = StatusCodeInterface::STATUS_OK, $headers = []): ResponseInterface 1146ccdf4f0SGreg Roach{ 1156ccdf4f0SGreg Roach if ($headers === []) { 1166ccdf4f0SGreg Roach if (is_string($content)) { 1176ccdf4f0SGreg Roach $headers = [ 1181b3d4731SGreg Roach 'Content-Type' => 'text/html; charset=utf-8', 1191b3d4731SGreg Roach 'Content-Length' => strlen($content), 1206ccdf4f0SGreg Roach ]; 1216ccdf4f0SGreg Roach } else { 1226ccdf4f0SGreg Roach $content = json_encode($content, JSON_HEX_TAG | JSON_HEX_APOS | JSON_HEX_AMP | JSON_HEX_QUOT); 1236ccdf4f0SGreg Roach $headers = [ 1241b3d4731SGreg Roach 'Content-Type' => 'application/json', 1251b3d4731SGreg Roach 'Content-Length' => strlen($content), 1266ccdf4f0SGreg Roach ]; 1276ccdf4f0SGreg Roach } 1286ccdf4f0SGreg Roach } 1296ccdf4f0SGreg Roach 1306ccdf4f0SGreg Roach /** @var ResponseFactoryInterface $response_factory */ 1316ccdf4f0SGreg Roach $response_factory = app(ResponseFactoryInterface::class); 1326ccdf4f0SGreg Roach 1336ccdf4f0SGreg Roach /** @var StreamFactoryInterface $stream_factory */ 1346ccdf4f0SGreg Roach $stream_factory = app(StreamFactoryInterface::class); 1356ccdf4f0SGreg Roach 1366ccdf4f0SGreg Roach $stream = $stream_factory->createStream($content); 1376ccdf4f0SGreg Roach 1386ccdf4f0SGreg Roach $response = $response_factory 1396ccdf4f0SGreg Roach ->createResponse($code) 1406ccdf4f0SGreg Roach ->withBody($stream); 1416ccdf4f0SGreg Roach 1426ccdf4f0SGreg Roach foreach ($headers as $key => $value) { 1436ccdf4f0SGreg Roach $response = $response->withHeader($key, $value); 1446ccdf4f0SGreg Roach } 1456ccdf4f0SGreg Roach 1466ccdf4f0SGreg Roach return $response; 1478655ee66SGreg Roach} 1488655ee66SGreg Roach 1498655ee66SGreg Roach/** 1501f3fb95cSGreg Roach * Generate a URL for a named route. 1511f3fb95cSGreg Roach * 1521f3fb95cSGreg Roach * @param string $route 1531f3fb95cSGreg Roach * @param array $parameters 154571e6fcaSGreg Roach * @param bool $absolute 1551f3fb95cSGreg Roach * 1561f3fb95cSGreg Roach * @return string 1571f3fb95cSGreg Roach */ 158c1010edaSGreg Roachfunction route(string $route, array $parameters = [], bool $absolute = true): string 159c1010edaSGreg Roach{ 1601f3fb95cSGreg Roach $parameters = ['route' => $route] + $parameters; 1611f3fb95cSGreg Roach 162571e6fcaSGreg Roach if ($absolute) { 1639b93b7c3SGreg Roach $base_url = app(ServerRequestInterface::class)->getAttribute('base_url'); 1649b93b7c3SGreg Roach 1659b93b7c3SGreg Roach return Html::url($base_url . 'index.php', $parameters); 1661f3fb95cSGreg Roach } 167b2ce94c6SRico Sonntag 1686ccdf4f0SGreg Roach return Html::url('index.php', $parameters); 169571e6fcaSGreg Roach} 1708655ee66SGreg Roach 1718655ee66SGreg Roach/** 1728655ee66SGreg Roach * Cerate and render a view in a single operation. 1738655ee66SGreg Roach * 1748655ee66SGreg Roach * @param string $name 1758655ee66SGreg Roach * @param mixed[] $data 1768655ee66SGreg Roach * 1778655ee66SGreg Roach * @return string 1788655ee66SGreg Roach */ 179c1010edaSGreg Roachfunction view(string $name, array $data = []) 180c1010edaSGreg Roach{ 1818898179dSGreg Roach return WebtreesView::make($name, $data); 1828655ee66SGreg Roach} 183