PluginProbe ʕ •ᴥ•ʔ
Matomo Analytics – Powerful, Privacy-First Insights for WordPress / trunk
Matomo Analytics – Powerful, Privacy-First Insights for WordPress vtrunk
5.11.1 5.11.0 5.10.2 5.10.1 trunk 1.0.2 1.0.3 1.0.4 1.0.5 1.0.6 1.1.0 1.1.1 1.1.2 1.1.3 1.2.0 1.3.0 1.3.1 1.3.2 4.0.0 4.0.1 4.0.2 4.0.3 4.0.4 4.1.0 4.1.1 4.1.2 4.1.3 4.10.0 4.11.0 4.12.0 4.13.0 4.13.2 4.13.3 4.13.4 4.13.5 4.14.0 4.14.1 4.14.2 4.15.0 4.15.1 4.15.2 4.15.3 4.2.0 4.3.0 4.3.1 4.4.1 4.4.2 4.5.0 4.6.0 5.0.1 5.0.2 5.0.3 5.0.4 5.0.5 5.0.6 5.0.7 5.0.8 5.1.0 5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7 5.10.0 5.2.0 5.2.1 5.2.2 5.3.0 5.3.1 5.3.2 5.3.3 5.6.0 5.6.1 5.7.0 5.7.1 5.8.0 5.8.1 5.8.2
matomo / app / core / Settings / Plugin / SystemSetting.php
matomo / app / core / Settings / Plugin Last commit date
SystemConfigSetting.php 1 month ago SystemSetting.php 1 month ago SystemSettings.php 1 month ago UserSetting.php 1 month ago UserSettings.php 1 month ago
SystemSetting.php
82 lines
1 <?php
2
3 /**
4 * Matomo - free/libre analytics platform
5 *
6 * @link https://matomo.org
7 * @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
8 */
9 namespace Piwik\Settings\Plugin;
10
11 use Piwik\Config;
12 use Piwik\Container\StaticContainer;
13 use Piwik\Piwik;
14 use Piwik\Settings\Setting;
15 /**
16 * Describes a system wide setting. Only the Super User can change this type of setting by default and
17 * the value of this setting will affect all users.
18 *
19 * See {@link \Piwik\Settings\Setting}.
20 *
21 * @api
22 */
23 class SystemSetting extends Setting
24 {
25 /**
26 * @param string $name The setting's persisted name.
27 * @param mixed $defaultValue Default value for this setting if no value was specified.
28 * @param string $type Eg an array, int, ... see TYPE_* constants
29 * @param string $pluginName The name of the plugin the system setting belongs to.
30 */
31 public function __construct($name, $defaultValue, $type, $pluginName)
32 {
33 parent::__construct($name, $defaultValue, $type, $pluginName);
34 $factory = StaticContainer::get('Piwik\\Settings\\Storage\\Factory');
35 $this->storage = $factory->getPluginStorage($this->pluginName, $userLogin = '');
36 }
37 /**
38 * Returns `true` if this setting is writable for the current user, `false` if otherwise. In case it returns
39 * writable for the current user it will be visible in the Plugin settings UI.
40 *
41 * @return bool
42 */
43 public function isWritableByCurrentUser()
44 {
45 if ($this->hasConfigValue()) {
46 return \false;
47 }
48 if (isset($this->hasWritePermission)) {
49 return $this->hasWritePermission;
50 }
51 // performance improvement, do not detect this in __construct otherwise likely rather "big" query to DB.
52 $this->hasWritePermission = Piwik::hasUserSuperUserAccess();
53 return $this->hasWritePermission;
54 }
55 /**
56 * @inheritdoc
57 */
58 public function getValue()
59 {
60 $defaultValue = parent::getValue();
61 // we access value first to make sure permissions are checked
62 $configValue = $this->getValueFromConfig();
63 if (isset($configValue)) {
64 $defaultValue = $configValue;
65 settype($defaultValue, $this->type);
66 }
67 return $defaultValue;
68 }
69 private function hasConfigValue()
70 {
71 $value = $this->getValueFromConfig();
72 return isset($value);
73 }
74 private function getValueFromConfig()
75 {
76 $config = Config::getInstance()->{$this->pluginName};
77 if (!empty($config) && array_key_exists($this->name, $config)) {
78 return $config[$this->name];
79 }
80 }
81 }
82