xref: /webtrees/app/Helpers/functions.php (revision 3976b4703df669696105ed6b024b96d433c8fbdb)
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