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 / Config / Cache.php
matomo / app / core / Config Last commit date
Cache.php 1 year ago ConfigNotFoundException.php 2 years ago DatabaseConfig.php 1 year ago GeneralConfig.php 2 years ago IniFileChain.php 1 month ago SectionConfig.php 1 month ago
Cache.php
77 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\Config;
10
11 use Matomo\Cache\Backend\File;
12 use Piwik\Common;
13 use Piwik\Piwik;
14 use Piwik\Url;
15 /**
16 * Exception thrown when the config file doesn't exist.
17 */
18 class Cache extends File
19 {
20 private $host = '';
21 public function __construct()
22 {
23 $this->host = $this->getHost();
24 // because the config is not yet loaded we cannot identify the instanceId...
25 // need to use the hostname
26 $dir = $this->makeCacheDir($this->host);
27 parent::__construct($dir);
28 }
29 private function makeCacheDir($host)
30 {
31 return PIWIK_INCLUDE_PATH . '/tmp/' . $host . '/cache/tracker';
32 }
33 public static function hasHostConfig($mergedConfigSettings)
34 {
35 return isset($mergedConfigSettings['General']['trusted_hosts']) && is_array($mergedConfigSettings['General']['trusted_hosts']);
36 }
37 public function isValidHost($mergedConfigSettings)
38 {
39 if (!self::hasHostConfig($mergedConfigSettings)) {
40 return \false;
41 }
42 // note: we do not support "enable_trusted_host_check" to keep things secure
43 return in_array($this->host, $mergedConfigSettings['General']['trusted_hosts'], \true);
44 }
45 private function getHost()
46 {
47 $host = Url::getHost($checkIfTrusted = \false);
48 $host = Url::getHostSanitized($host);
49 // Remove any port number to get actual hostname
50 $host = Common::sanitizeInputValue($host);
51 if (empty($host) || strpos($host, '..') !== \false || strpos($host, '\\') !== \false || strpos($host, '/') !== \false) {
52 throw new \Exception('Unsupported host');
53 }
54 $this->host = $host;
55 return $host;
56 }
57 public function doDelete($id)
58 {
59 // when the config changes, we need to invalidate the config caches for all configured hosts as well, not only
60 // the currently trusted host
61 $hosts = Url::getTrustedHosts();
62 $initialDir = $this->directory;
63 foreach ($hosts as $host) {
64 $dir = $this->makeCacheDir($host);
65 if (@is_dir($dir)) {
66 $this->directory = $dir;
67 $success = parent::doDelete($id);
68 if ($success) {
69 Piwik::postEvent('Core.configFileDeleted', [$this->getFilename($id)]);
70 }
71 }
72 }
73 $this->directory = $initialDir;
74 return \true;
75 }
76 }
77