xref: /webtrees/app/Site.php (revision 8fcd0d32e56ee262912bbdb593202cfd1cbc1615)
1a25f0a04SGreg Roach<?php
2a25f0a04SGreg Roach/**
3a25f0a04SGreg Roach * webtrees: online genealogy
4*8fcd0d32SGreg Roach * Copyright (C) 2019 webtrees development team
5a25f0a04SGreg Roach * This program is free software: you can redistribute it and/or modify
6a25f0a04SGreg Roach * it under the terms of the GNU General Public License as published by
7a25f0a04SGreg Roach * the Free Software Foundation, either version 3 of the License, or
8a25f0a04SGreg Roach * (at your option) any later version.
9a25f0a04SGreg Roach * This program is distributed in the hope that it will be useful,
10a25f0a04SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of
11a25f0a04SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12a25f0a04SGreg Roach * GNU General Public License for more details.
13a25f0a04SGreg Roach * You should have received a copy of the GNU General Public License
14a25f0a04SGreg Roach * along with this program. If not, see <http://www.gnu.org/licenses/>.
15a25f0a04SGreg Roach */
16e7f56f2aSGreg Roachdeclare(strict_types=1);
17e7f56f2aSGreg Roach
1876692c8bSGreg Roachnamespace Fisharebest\Webtrees;
19a25f0a04SGreg Roach
20b48bb5e9SGreg Roachuse Illuminate\Database\Capsule\Manager as DB;
21b48bb5e9SGreg Roachuse function mb_substr;
22b48bb5e9SGreg Roach
23a25f0a04SGreg Roach/**
2476692c8bSGreg Roach * Provide an interface to the wt_site_setting table.
25a25f0a04SGreg Roach */
26c1010edaSGreg Roachclass Site
27c1010edaSGreg Roach{
28a25f0a04SGreg Roach    /**
29a25f0a04SGreg Roach     * Everything from the wt_site_setting table.
30a25f0a04SGreg Roach     *
31a25f0a04SGreg Roach     * @var array
32a25f0a04SGreg Roach     */
3332f20c14SGreg Roach    public static $preferences = [];
34a25f0a04SGreg Roach
35a25f0a04SGreg Roach    /**
36a25f0a04SGreg Roach     * Get the site’s configuration settings
37a25f0a04SGreg Roach     *
38a25f0a04SGreg Roach     * @param string $setting_name
3915d603e7SGreg Roach     * @param string $default
40a25f0a04SGreg Roach     *
4115d603e7SGreg Roach     * @return string
42a25f0a04SGreg Roach     */
43acf76a54SGreg Roach    public static function getPreference(string $setting_name, string $default = ''): string
44c1010edaSGreg Roach    {
45a25f0a04SGreg Roach        // There are lots of settings, and we need to fetch lots of them on every page
46a25f0a04SGreg Roach        // so it is quicker to fetch them all in one go.
4715d603e7SGreg Roach        if (empty(self::$preferences)) {
48b48bb5e9SGreg Roach            self::$preferences = DB::table('site_setting')
49b48bb5e9SGreg Roach                ->pluck('setting_value', 'setting_name')
50b48bb5e9SGreg Roach                ->all();
51a25f0a04SGreg Roach        }
52a25f0a04SGreg Roach
53acf76a54SGreg Roach        return self::$preferences[$setting_name] ?? $default;
54a25f0a04SGreg Roach    }
55a25f0a04SGreg Roach
56a25f0a04SGreg Roach    /**
57a25f0a04SGreg Roach     * Set the site’s configuration settings.
58a25f0a04SGreg Roach     *
59a25f0a04SGreg Roach     * @param string $setting_name
6015d603e7SGreg Roach     * @param string $setting_value
61c7ff4153SGreg Roach     *
62c7ff4153SGreg Roach     * @return void
63a25f0a04SGreg Roach     */
64c1010edaSGreg Roach    public static function setPreference($setting_name, $setting_value)
65c1010edaSGreg Roach    {
6632f20c14SGreg Roach        // The database column is only this long.
6732f20c14SGreg Roach        $setting_value = mb_substr($setting_value, 0, 2000);
6832f20c14SGreg Roach
6915d603e7SGreg Roach        if (self::getPreference($setting_name) !== $setting_value) {
70b48bb5e9SGreg Roach            DB::table('site_setting')->updateOrInsert([
71a25f0a04SGreg Roach                'setting_name' => $setting_name,
72b48bb5e9SGreg Roach            ], [
7332f20c14SGreg Roach                'setting_value' => $setting_value,
7413abd6f3SGreg Roach            ]);
75a25f0a04SGreg Roach
7615d603e7SGreg Roach            self::$preferences[$setting_name] = $setting_value;
77a25f0a04SGreg Roach
78847d5489SGreg Roach            Log::addConfigurationLog('Site preference "' . $setting_name . '" set to "' . $setting_value . '"', null);
79a25f0a04SGreg Roach        }
80a25f0a04SGreg Roach    }
81a25f0a04SGreg Roach}
82