From 36506cd07cf36bdc4dfea625012c1e61c5ae88b7 Mon Sep 17 00:00:00 2001 From: Florian Date: Mon, 11 Dec 2023 19:43:39 +0100 Subject: [PATCH] fix(php): open_basedir restriction (#944) * Only load composer cache, when required * Reverted short syntax * Remain empty line * Made Psalm happy again * Removed spaces in empty line --- packages/php/src/Metrics.php | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/packages/php/src/Metrics.php b/packages/php/src/Metrics.php index 4109e5cd2c..59a5035f58 100644 --- a/packages/php/src/Metrics.php +++ b/packages/php/src/Metrics.php @@ -29,7 +29,7 @@ class Metrics private Client $readme_api_client; private string|null $package_version; - private string $cache_dir; + private string|null $cache_dir; private string $user_agent; /** @@ -80,7 +80,7 @@ public function __construct(public string $api_key, public string $group_handler ]); $this->package_version = InstalledVersions::getVersion(self::PACKAGE_NAME); - $this->cache_dir = Factory::createConfig()->get('cache-dir'); + $this->cache_dir = null; $this->user_agent = 'readme-metrics-php/' . ($this->package_version ?? 'unknown'); } @@ -247,7 +247,20 @@ public function getCacheFile(): string // Replace potentially unsafe characters in the cache key so it can be safely used as a filename on the server. $cache_key = str_replace([DIRECTORY_SEPARATOR, '@'], '-', $cache_key); - return $this->cache_dir . DIRECTORY_SEPARATOR . $cache_key; + return $this->getCacheDir() . DIRECTORY_SEPARATOR . $cache_key; + } + + /** + * Retrieve the cache dir where the cache file will be stored. + * + */ + public function getCacheDir(): string + { + if ($this->cache_dir === null) { + $this->cache_dir = Factory::createConfig()->get('cache-dir'); + } + + return $this->cache_dir; } public function getPackageVersion(): ?string