PluginProbe ʕ •ᴥ•ʔ
Matomo Analytics – Powerful, Privacy-First Insights for WordPress / 1.3.1
Matomo Analytics – Powerful, Privacy-First Insights for WordPress v1.3.1
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 / UserSettings.php
matomo / app / core / Settings / Plugin Last commit date
SystemConfigSetting.php 6 years ago SystemSetting.php 6 years ago SystemSettings.php 6 years ago UserSetting.php 6 years ago UserSettings.php 6 years ago
UserSettings.php
94 lines
1 <?php
2 /**
3 * Piwik - free/libre analytics platform
4 *
5 * @link https://matomo.org
6 * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
7 *
8 */
9 namespace Piwik\Settings\Plugin;
10
11 use Piwik\Db;
12 use Piwik\Piwik;
13 use Piwik\Settings\Settings;
14 use Piwik\Settings\Storage;
15
16 /**
17 * Base class of all plugin settings providers. Plugins that define their own configuration settings
18 * can extend this class to easily make their settings available to Piwik users.
19 *
20 * Descendants of this class should implement the {@link init()} method and call the
21 * {@link addSetting()} method for each of the plugin's settings.
22 *
23 * For an example, see {@link Piwik\Plugins\ExampleSettingsPlugin\UserSettings}.
24 *
25 * $userSettings = new Piwik\Plugins\ExampleSettingsPlugin\UserSettings(); // get instance via dependency injection
26 * $userSettings->yourSetting->getValue();
27 *
28 * @api
29 */
30 abstract class UserSettings extends Settings
31 {
32 /**
33 * Constructor.
34 */
35 public function __construct()
36 {
37 parent::__construct();
38
39 $this->init();
40 }
41
42 /**
43 * Creates a new user setting.
44 *
45 * Settings will be displayed in the UI depending on the order of `makeSetting` calls. This means you can define
46 * the order of the displayed settings by calling makeSetting first for more important settings.
47 *
48 * @param string $name The name of the setting that shall be created
49 * @param mixed $defaultValue The default value for this setting. Note the value will not be converted to the
50 * specified type.
51 * @param string $type The PHP internal type the value of this setting should have.
52 * Use one of FieldConfig::TYPE_* constancts
53 * @param \Closure $fieldConfigCallback A callback method to configure the field that shall be displayed in the
54 * UI to define the value for this setting
55 * @return UserSetting Returns an instance of the created measurable setting.
56 */
57 protected function makeSetting($name, $defaultValue, $type, $configureCallback)
58 {
59 $userLogin = Piwik::getCurrentUserLogin();
60
61 $setting = new UserSetting($name, $defaultValue, $type, $this->pluginName, $userLogin);
62 $setting->setConfigureCallback($configureCallback);
63
64 $this->addSetting($setting);
65 return $setting;
66 }
67
68 /**
69 * Saves (persists) the current setting values in the database.
70 *
71 * Will trigger an event to notify plugins that a value has been changed.
72 */
73 public function save()
74 {
75 parent::save();
76
77 /**
78 * Triggered after user settings have been updated.
79 *
80 * **Example**
81 *
82 * Piwik::addAction('UserSettings.updated', function (UserSettings $settings) {
83 * if ($settings->getPluginName() === 'PluginName') {
84 * $value = $settings->someSetting->getValue();
85 * // Do something with the new setting value
86 * }
87 * });
88 *
89 * @param Settings $settings The plugin settings object.
90 */
91 Piwik::postEvent('UserSettings.updated', array($this));
92 }
93 }
94