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 / UserSetting.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
UserSetting.php
60 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\Container\StaticContainer;
12 use Piwik\Piwik;
13 use Exception;
14 use Piwik\Settings\Setting;
15 /**
16 * Describes a per user setting. Each user will be able to change this setting for themselves,
17 * but not for other users.
18 *
19 * See {@link \Piwik\Settings\Setting}.
20 */
21 class UserSetting extends Setting
22 {
23 /**
24 * @var null|string
25 */
26 private $userLogin = null;
27 /**
28 * @param string $name The setting's persisted name.
29 * @param mixed $defaultValue Default value for this setting if no value was specified.
30 * @param string $type Eg an array, int, ... see TYPE_* constants
31 * @param string $pluginName The name of the plugin the setting belongs to
32 * @param string $userLogin The name of the user the value should be set or get for
33 * @throws Exception
34 */
35 public function __construct($name, $defaultValue, $type, $pluginName, $userLogin)
36 {
37 parent::__construct($name, $defaultValue, $type, $pluginName);
38 if (empty($userLogin)) {
39 throw new Exception('No userLogin given to create setting ' . $name);
40 }
41 $this->userLogin = $userLogin;
42 $factory = StaticContainer::get('Piwik\\Settings\\Storage\\Factory');
43 $this->storage = $factory->getPluginStorage($this->pluginName, $this->userLogin);
44 }
45 /**
46 * Returns `true` if this setting can be displayed for the current user, `false` if otherwise.
47 *
48 * @return bool
49 */
50 public function isWritableByCurrentUser()
51 {
52 if (isset($this->hasWritePermission)) {
53 return $this->hasWritePermission;
54 }
55 // performance improvement, do not detect this in __construct otherwise likely rather "big" query to DB.
56 $this->hasWritePermission = Piwik::isUserHasSomeViewAccess();
57 return $this->hasWritePermission;
58 }
59 }
60