refactor: use static values for cache scope

This fixes a future problem when code is placed under a namespace because `get_class($bridge)` will then return e.g. `RssBridge\Bridge\TwitterBridge` instead of the the current value `TwitterBridge`.

Also a bit refactoring of `Configuration.php`.
This commit is contained in:
Dag 2022-08-02 15:03:54 +02:00 committed by GitHub
parent a0a0d5235b
commit ecb486794b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
11 changed files with 42 additions and 41 deletions

View File

@ -116,7 +116,7 @@ class ElloBridge extends BridgeAbstract
$cacheFactory = new CacheFactory(); $cacheFactory = new CacheFactory();
$cache = $cacheFactory->create(); $cache = $cacheFactory->create();
$cache->setScope(get_called_class()); $cache->setScope('ElloBridge');
$cache->setKey(['key']); $cache->setKey(['key']);
$key = $cache->loadData(); $key = $cache->loadData();

View File

@ -101,7 +101,7 @@ class InstagramBridge extends BridgeAbstract
$cacheFactory = new CacheFactory(); $cacheFactory = new CacheFactory();
$cache = $cacheFactory->create(); $cache = $cacheFactory->create();
$cache->setScope(get_called_class()); $cache->setScope('InstagramBridge');
$cache->setKey([$username]); $cache->setKey([$username]);
$key = $cache->loadData(); $key = $cache->loadData();

View File

@ -125,7 +125,7 @@ HTML;
$cacheFactory = new CacheFactory(); $cacheFactory = new CacheFactory();
$this->clientIDCache = $cacheFactory->create(); $this->clientIDCache = $cacheFactory->create();
$this->clientIDCache->setScope(get_called_class()); $this->clientIDCache->setScope('SoundCloudBridge');
$this->clientIDCache->setKey(['client_id']); $this->clientIDCache->setKey(['client_id']);
} }

View File

@ -103,7 +103,7 @@ class SpotifyBridge extends BridgeAbstract
$cacheFactory = new CacheFactory(); $cacheFactory = new CacheFactory();
$cache = $cacheFactory->create(); $cache = $cacheFactory->create();
$cache->setScope(get_called_class()); $cache->setScope('SpotifyBridge');
$cache->setKey(['token']); $cache->setKey(['token']);
if ($cache->getTime()) { if ($cache->getTime()) {

View File

@ -506,7 +506,8 @@ EOD;
$cacheFactory = new CacheFactory(); $cacheFactory = new CacheFactory();
$r_cache = $cacheFactory->create(); $r_cache = $cacheFactory->create();
$r_cache->setScope(get_called_class()); $scope = 'TwitterBridge';
$r_cache->setScope($scope);
$r_cache->setKey(['refresh']); $r_cache->setKey(['refresh']);
$data = $r_cache->loadData(); $data = $r_cache->loadData();
@ -521,7 +522,7 @@ EOD;
$cacheFactory = new CacheFactory(); $cacheFactory = new CacheFactory();
$cache = $cacheFactory->create(); $cache = $cacheFactory->create();
$cache->setScope(get_called_class()); $cache->setScope($scope);
$cache->setKey(['api_key']); $cache->setKey(['api_key']);
$data = $cache->loadData(); $data = $cache->loadData();
@ -558,7 +559,7 @@ EOD;
$cacheFac2 = new CacheFactory(); $cacheFac2 = new CacheFactory();
$gt_cache = $cacheFactory->create(); $gt_cache = $cacheFactory->create();
$gt_cache->setScope(get_called_class()); $gt_cache->setScope($scope);
$gt_cache->setKey(['guest_token']); $gt_cache->setKey(['guest_token']);
$guestTokenUses = $gt_cache->loadData(); $guestTokenUses = $gt_cache->loadData();

View File

@ -15,22 +15,23 @@ class MemcachedCache implements CacheInterface
returnServerError('"memcached" extension not loaded. Please check "php.ini"'); returnServerError('"memcached" extension not loaded. Please check "php.ini"');
} }
$host = Configuration::getConfig(get_called_class(), 'host'); $section = 'MemcachedCache';
$port = Configuration::getConfig(get_called_class(), 'port'); $host = Configuration::getConfig($section, 'host');
$port = Configuration::getConfig($section, 'port');
if (empty($host) && empty($port)) { if (empty($host) && empty($port)) {
returnServerError('Configuration for ' . get_called_class() . ' missing. Please check your ' . FILE_CONFIG); returnServerError('Configuration for ' . $section . ' missing. Please check your ' . FILE_CONFIG);
} elseif (empty($host)) { } elseif (empty($host)) {
returnServerError('"host" param is not set for ' . get_called_class() . '. Please check your ' . FILE_CONFIG); returnServerError('"host" param is not set for ' . $section . '. Please check your ' . FILE_CONFIG);
} elseif (empty($port)) { } elseif (empty($port)) {
returnServerError('"port" param is not set for ' . get_called_class() . '. Please check your ' . FILE_CONFIG); returnServerError('"port" param is not set for ' . $section . '. Please check your ' . FILE_CONFIG);
} elseif (!ctype_digit($port)) { } elseif (!ctype_digit($port)) {
returnServerError('"port" param is invalid for ' . get_called_class() . '. Please check your ' . FILE_CONFIG); returnServerError('"port" param is invalid for ' . $section . '. Please check your ' . FILE_CONFIG);
} }
$port = intval($port); $port = intval($port);
if ($port < 1 || $port > 65535) { if ($port < 1 || $port > 65535) {
returnServerError('"port" param is invalid for ' . get_called_class() . '. Please check your ' . FILE_CONFIG); returnServerError('"port" param is invalid for ' . $section . '. Please check your ' . FILE_CONFIG);
} }
$conn = new Memcached(); $conn = new Memcached();

View File

@ -24,16 +24,17 @@ class SQLiteCache implements CacheInterface
); );
} }
$file = Configuration::getConfig(get_called_class(), 'file'); $section = 'SQLiteCache';
$file = Configuration::getConfig($section, 'file');
if (empty($file)) { if (empty($file)) {
$message = sprintf('Configuration for %s missing. Please check your %s', get_called_class(), FILE_CONFIG); $message = sprintf('Configuration for %s missing. Please check your %s', $section, FILE_CONFIG);
print render('error.html.php', ['message' => $message]); print render('error.html.php', ['message' => $message]);
exit; exit;
} }
if (dirname($file) == '.') { if (dirname($file) == '.') {
$file = PATH_CACHE . $file; $file = PATH_CACHE . $file;
} elseif (!is_dir(dirname($file))) { } elseif (!is_dir(dirname($file))) {
$message = sprintf('Invalid configuration for %s. Please check your %s', get_called_class(), FILE_CONFIG); $message = sprintf('Invalid configuration for %s. Please check your %s', $section, FILE_CONFIG);
print render('error.html.php', ['message' => $message]); print render('error.html.php', ['message' => $message]);
exit; exit;
} }

View File

@ -4,6 +4,11 @@ require_once __DIR__ . '/lib/rssbridge.php';
Configuration::verifyInstallation(); Configuration::verifyInstallation();
Configuration::loadConfiguration(); Configuration::loadConfiguration();
date_default_timezone_set(Configuration::getConfig('system', 'timezone'));
define('CUSTOM_CACHE_TIMEOUT', Configuration::getConfig('cache', 'custom_timeout'));
Authentication::showPromptIfNeeded(); Authentication::showPromptIfNeeded();
try { try {

View File

@ -280,7 +280,8 @@ abstract class BridgeAbstract implements BridgeInterface
public function loadConfiguration() public function loadConfiguration()
{ {
foreach (static::CONFIGURATION as $optionName => $optionValue) { foreach (static::CONFIGURATION as $optionName => $optionValue) {
$configurationOption = Configuration::getConfig(get_class($this), $optionName); $section = (new ReflectionClass($this))->getShortName();
$configurationOption = Configuration::getConfig($section, $optionName);
if ($configurationOption !== null) { if ($configurationOption !== null) {
$this->configuration[$optionName] = $configurationOption; $this->configuration[$optionName] = $configurationOption;
@ -408,7 +409,9 @@ abstract class BridgeAbstract implements BridgeInterface
$cacheFactory = new CacheFactory(); $cacheFactory = new CacheFactory();
$cache = $cacheFactory->create(); $cache = $cacheFactory->create();
$cache->setScope(get_called_class()); // Create class name without the namespace part
$scope = (new ReflectionClass($this))->getShortName();
$cache->setScope($scope);
$cache->setKey($key); $cache->setKey($key);
if ($cache->getTime() < time() - $duration) { if ($cache->getTime() < time() - $duration) {
return null; return null;
@ -427,7 +430,8 @@ abstract class BridgeAbstract implements BridgeInterface
$cacheFactory = new CacheFactory(); $cacheFactory = new CacheFactory();
$cache = $cacheFactory->create(); $cache = $cacheFactory->create();
$cache->setScope(get_called_class()); $scope = (new ReflectionClass($this))->getShortName();
$cache->setScope($scope);
$cache->setKey($key); $cache->setKey($key);
$cache->saveData($value); $cache->saveData($value);
} }

View File

@ -131,8 +131,8 @@ final class Configuration
self::reportError('The default configuration file is missing at ' . FILE_CONFIG_DEFAULT); self::reportError('The default configuration file is missing at ' . FILE_CONFIG_DEFAULT);
} }
Configuration::$config = parse_ini_file(FILE_CONFIG_DEFAULT, true, INI_SCANNER_TYPED); $config = parse_ini_file(FILE_CONFIG_DEFAULT, true, INI_SCANNER_TYPED);
if (!Configuration::$config) { if (!$config) {
self::reportError('Error parsing ' . FILE_CONFIG_DEFAULT); self::reportError('Error parsing ' . FILE_CONFIG_DEFAULT);
} }
@ -140,24 +140,26 @@ final class Configuration
// Replace default configuration with custom settings // Replace default configuration with custom settings
foreach (parse_ini_file(FILE_CONFIG, true, INI_SCANNER_TYPED) as $header => $section) { foreach (parse_ini_file(FILE_CONFIG, true, INI_SCANNER_TYPED) as $header => $section) {
foreach ($section as $key => $value) { foreach ($section as $key => $value) {
Configuration::$config[$header][$key] = $value; $config[$header][$key] = $value;
} }
} }
} }
foreach (getenv() as $envkey => $value) { foreach (getenv() as $envName => $envValue) {
// Replace all settings with their respective environment variable if available // Replace all settings with their respective environment variable if available
$keyArray = explode('_', $envkey); $keyArray = explode('_', $envName);
if ($keyArray[0] === 'RSSBRIDGE') { if ($keyArray[0] === 'RSSBRIDGE') {
$header = strtolower($keyArray[1]); $header = strtolower($keyArray[1]);
$key = strtolower($keyArray[2]); $key = strtolower($keyArray[2]);
if ($value === 'true' || $value === 'false') { if ($envValue === 'true' || $envValue === 'false') {
$value = filter_var($value, FILTER_VALIDATE_BOOLEAN); $envValue = filter_var($envValue, FILTER_VALIDATE_BOOLEAN);
} }
Configuration::$config[$header][$key] = $value; $config[$header][$key] = $envValue;
} }
} }
self::$config = $config;
if ( if (
!is_string(self::getConfig('system', 'timezone')) !is_string(self::getConfig('system', 'timezone'))
|| !in_array(self::getConfig('system', 'timezone'), timezone_identifiers_list(DateTimeZone::ALL_WITH_BC)) || !in_array(self::getConfig('system', 'timezone'), timezone_identifiers_list(DateTimeZone::ALL_WITH_BC))
@ -165,14 +167,10 @@ final class Configuration
self::reportConfigurationError('system', 'timezone'); self::reportConfigurationError('system', 'timezone');
} }
date_default_timezone_set(self::getConfig('system', 'timezone'));
if (!is_string(self::getConfig('proxy', 'url'))) { if (!is_string(self::getConfig('proxy', 'url'))) {
/** URL of the proxy server */
self::reportConfigurationError('proxy', 'url', 'Is not a valid string'); self::reportConfigurationError('proxy', 'url', 'Is not a valid string');
} }
/** True if proxy usage can be enabled selectively for each bridge */
if (!is_bool(self::getConfig('proxy', 'by_bridge'))) { if (!is_bool(self::getConfig('proxy', 'by_bridge'))) {
self::reportConfigurationError('proxy', 'by_bridge', 'Is not a valid Boolean'); self::reportConfigurationError('proxy', 'by_bridge', 'Is not a valid Boolean');
} }
@ -190,9 +188,6 @@ final class Configuration
self::reportConfigurationError('cache', 'custom_timeout', 'Is not a valid Boolean'); self::reportConfigurationError('cache', 'custom_timeout', 'Is not a valid Boolean');
} }
/** True if the cache timeout can be specified by the user */
define('CUSTOM_CACHE_TIMEOUT', self::getConfig('cache', 'custom_timeout'));
if (!is_bool(self::getConfig('authentication', 'enable'))) { if (!is_bool(self::getConfig('authentication', 'enable'))) {
self::reportConfigurationError('authentication', 'enable', 'Is not a valid Boolean'); self::reportConfigurationError('authentication', 'enable', 'Is not a valid Boolean');
} }

View File

@ -21,11 +21,5 @@ final class ConfigurationTest extends TestCase
// test value from env // test value from env
$this->assertSame('Europe/Berlin', Configuration::getConfig('system', 'timezone')); $this->assertSame('Europe/Berlin', Configuration::getConfig('system', 'timezone'));
// test real values
$this->assertSame('file', Configuration::getConfig('cache', 'type'));
$this->assertSame(false, Configuration::getConfig('authentication', 'enable'));
$this->assertSame(true, Configuration::getConfig('admin', 'donations'));
$this->assertSame(1, Configuration::getConfig('error', 'report_limit'));
} }
} }