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 / SystemSettings.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
SystemSettings.php
100 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\Piwik;
12 use Piwik\Settings\Settings;
13 /**
14 * Base class of all system settings providers. Plugins that define their own configuration settings
15 * can extend this class to easily make their system settings available to Piwik users.
16 *
17 * Descendants of this class should implement the {@link init()} method and call the
18 * {@link makeSetting()} method to create a system setting for this plugin.
19 *
20 * For an example, see {@link Piwik\Plugins\ExampleSettingsPlugin\SystemSettings}.
21 *
22 * $systemSettings = new Piwik\Plugins\ExampleSettingsPlugin\SystemSettings(); // get instance via dependency injection
23 * $systemSettings->yourSetting->getValue();
24 *
25 * @api
26 */
27 abstract class SystemSettings extends Settings
28 {
29 public function __construct()
30 {
31 parent::__construct();
32 $this->init();
33 }
34 /**
35 * Creates a new system setting.
36 *
37 * Settings will be displayed in the UI depending on the order of `makeSetting` calls. This means you can define
38 * the order of the displayed settings by calling makeSetting first for more important settings.
39 *
40 * @param string $name The name of the setting that shall be created
41 * @param mixed $defaultValue The default value for this setting. Note the value will not be converted to the
42 * specified type.
43 * @param string $type The PHP internal type the value of this setting should have.
44 * Use one of FieldConfig::TYPE_* constants
45 * @param \Closure $fieldConfigCallback A callback method to configure the field that shall be displayed in the
46 * UI to define the value for this setting
47 * @return SystemSetting Returns an instance of the created measurable setting.
48 */
49 protected function makeSetting($name, $defaultValue, $type, $fieldConfigCallback)
50 {
51 $setting = new \Piwik\Settings\Plugin\SystemSetting($name, $defaultValue, $type, $this->pluginName);
52 $setting->setConfigureCallback($fieldConfigCallback);
53 $this->addSetting($setting);
54 return $setting;
55 }
56 /**
57 * This is only meant for some core features used by some core plugins that are shipped with Piwik
58 * @internal
59 * @ignore
60 * @param string $configSectionName
61 * @param $name
62 * @param $defaultValue
63 * @param $type
64 * @param $fieldConfigCallback
65 * @return SystemSetting
66 * @throws \Exception
67 */
68 protected function makeSettingManagedInConfigOnly($configSectionName, $name, $defaultValue, $type, $fieldConfigCallback)
69 {
70 $setting = new \Piwik\Settings\Plugin\SystemConfigSetting($name, $defaultValue, $type, $this->pluginName, $configSectionName);
71 $setting->setConfigureCallback($fieldConfigCallback);
72 $this->addSetting($setting);
73 return $setting;
74 }
75 /**
76 * Saves (persists) the current setting values in the database.
77 *
78 * Will trigger an event to notify plugins that a value has been changed.
79 */
80 public function save()
81 {
82 parent::save();
83 /**
84 * Triggered after system settings have been updated.
85 *
86 * **Example**
87 *
88 * Piwik::addAction('SystemSettings.updated', function (SystemSettings $settings) {
89 * if ($settings->getPluginName() === 'PluginName') {
90 * $value = $settings->someSetting->getValue();
91 * // Do something with the new setting value
92 * }
93 * });
94 *
95 * @param Settings $settings The plugin settings object.
96 */
97 Piwik::postEvent('SystemSettings.updated', array($this));
98 }
99 }
100