Refactor IManageConfigValues interface
This commit is contained in:
parent
326566638f
commit
1e574d5383
13 changed files with 46 additions and 49 deletions
|
@ -71,7 +71,7 @@ if (DI::mode()->isInstall()) {
|
||||||
|
|
||||||
DI::mode()->setExecutor(Mode::DAEMON);
|
DI::mode()->setExecutor(Mode::DAEMON);
|
||||||
|
|
||||||
DI::config()->load();
|
DI::config()->reload();
|
||||||
|
|
||||||
if (empty(DI::config()->get('system', 'pidfile'))) {
|
if (empty(DI::config()->get('system', 'pidfile'))) {
|
||||||
die(<<<TXT
|
die(<<<TXT
|
||||||
|
|
|
@ -296,8 +296,7 @@ class App
|
||||||
*/
|
*/
|
||||||
public function getBasePath(): string
|
public function getBasePath(): string
|
||||||
{
|
{
|
||||||
// Don't use the basepath of the config table for basepath (it should always be the config-file one)
|
return $this->config->get('system', 'basepath');
|
||||||
return $this->config->getCache()->get('system', 'basepath');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -157,7 +157,7 @@ HELP;
|
||||||
|
|
||||||
if (count($this->args) == 1) {
|
if (count($this->args) == 1) {
|
||||||
$cat = $this->getArgument(0);
|
$cat = $this->getArgument(0);
|
||||||
$this->config->load($cat);
|
$this->config->reload();
|
||||||
$configCache = $this->config->getCache();
|
$configCache = $this->config->getCache();
|
||||||
|
|
||||||
if ($configCache->get($cat) !== null) {
|
if ($configCache->get($cat) !== null) {
|
||||||
|
@ -178,7 +178,7 @@ HELP;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count($this->args) == 0) {
|
if (count($this->args) == 0) {
|
||||||
$this->config->load();
|
$this->config->reload();
|
||||||
|
|
||||||
if ($this->config->get('system', 'config_adapter') == 'jit' && $this->appMode->has(App\Mode::DBCONFIGAVAILABLE)) {
|
if ($this->config->get('system', 'config_adapter') == 'jit' && $this->appMode->has(App\Mode::DBCONFIGAVAILABLE)) {
|
||||||
$this->out('Warning: The JIT (Just In Time) Config adapter doesn\'t support loading the entire configuration, showing file config only');
|
$this->out('Warning: The JIT (Just In Time) Config adapter doesn\'t support loading the entire configuration, showing file config only');
|
||||||
|
|
|
@ -30,36 +30,32 @@ use Friendica\Core\Config\ValueObject\Cache;
|
||||||
interface IManageConfigValues
|
interface IManageConfigValues
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Loads all configuration values of family into a cached storage.
|
* Reloads all configuration values (from filesystem and environment variables)
|
||||||
*
|
*
|
||||||
* All configuration values of the system are stored in the cache.
|
* All configuration values of the system are stored in the cache.
|
||||||
*
|
*
|
||||||
* @param string $cat The category of the configuration value
|
|
||||||
*
|
|
||||||
* @return void
|
* @return void
|
||||||
*
|
*
|
||||||
* @throws ConfigPersistenceException In case the persistence layer throws errors
|
* @throws ConfigPersistenceException In case the persistence layer throws errors
|
||||||
*/
|
*/
|
||||||
public function load(string $cat = 'config');
|
public function reload();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a particular user's config variable given the category name
|
* Get a particular user's config variable given the category name
|
||||||
* ($cat) and a $key.
|
* ($cat) and a $key.
|
||||||
*
|
*
|
||||||
* Get a particular config value from the given category ($cat)
|
* Get a particular config value from the given category ($cat)
|
||||||
* and the $key from a cached storage either from the database or from the cache.
|
|
||||||
*
|
*
|
||||||
* @param string $cat The category of the configuration value
|
* @param string $cat The category of the configuration value
|
||||||
* @param string $key The configuration key to query
|
* @param string $key The configuration key to query
|
||||||
* @param mixed $default_value Deprecated, use `Config->get($cat, $key, null, $refresh) ?? $default_value` instead
|
* @param mixed $default_value Deprecated, use `Config->get($cat, $key, null, $refresh) ?? $default_value` instead
|
||||||
* @param boolean $refresh optional, If true the config is loaded from the db and not from the cache (default: false)
|
|
||||||
*
|
*
|
||||||
* @return mixed Stored value or null if it does not exist
|
* @return mixed Stored value or null if it does not exist
|
||||||
*
|
*
|
||||||
* @throws ConfigPersistenceException In case the persistence layer throws errors
|
* @throws ConfigPersistenceException In case the persistence layer throws errors
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public function get(string $cat, string $key, $default_value = null, bool $refresh = false);
|
public function get(string $cat, string $key, $default_value = null);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets a configuration value for system config
|
* Sets a configuration value for system config
|
||||||
|
@ -81,6 +77,8 @@ interface IManageConfigValues
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Save back the overridden values of the config cache
|
* Save back the overridden values of the config cache
|
||||||
|
*
|
||||||
|
* @throws ConfigPersistenceException In case the persistence layer throws errors
|
||||||
*/
|
*/
|
||||||
public function save();
|
public function save();
|
||||||
|
|
||||||
|
|
|
@ -81,21 +81,4 @@ class Config
|
||||||
|
|
||||||
return $configCache;
|
return $configCache;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Cache $configCache The config cache of this adapter
|
|
||||||
* @param Repository\Config $configRepo The configuration repository
|
|
||||||
*
|
|
||||||
* @return Capability\IManageConfigValues
|
|
||||||
*/
|
|
||||||
public function create(Util\ConfigFileManager $loader, Cache $configCache, Repository\Config $configRepo)
|
|
||||||
{
|
|
||||||
if ($configCache->get('system', 'config_adapter') === 'preload') {
|
|
||||||
$configuration = new Type\PreloadConfig($loader, $configCache, $configRepo);
|
|
||||||
} else {
|
|
||||||
$configuration = new Type\JitConfig($loader, $configCache, $configRepo);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $configuration;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,8 @@
|
||||||
namespace Friendica\Core\Config\Model;
|
namespace Friendica\Core\Config\Model;
|
||||||
|
|
||||||
use Friendica\Core\Config\Capability\IManageConfigValues;
|
use Friendica\Core\Config\Capability\IManageConfigValues;
|
||||||
|
use Friendica\Core\Config\Exception\ConfigFileException;
|
||||||
|
use Friendica\Core\Config\Exception\ConfigPersistenceException;
|
||||||
use Friendica\Core\Config\Util\ConfigFileManager;
|
use Friendica\Core\Config\Util\ConfigFileManager;
|
||||||
use Friendica\Core\Config\ValueObject\Cache;
|
use Friendica\Core\Config\ValueObject\Cache;
|
||||||
|
|
||||||
|
@ -38,14 +40,19 @@ class Config implements IManageConfigValues
|
||||||
/** @var ConfigFileManager */
|
/** @var ConfigFileManager */
|
||||||
protected $configFileManager;
|
protected $configFileManager;
|
||||||
|
|
||||||
|
/** @var array */
|
||||||
|
protected $server;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param ConfigFileManager $configFileManager The configuration file manager to save back configs
|
* @param ConfigFileManager $configFileManager The configuration file manager to save back configs
|
||||||
* @param Cache $configCache The configuration cache (based on the config-files)
|
* @param Cache $configCache The configuration cache (based on the config-files)
|
||||||
|
* @param array $server The $_SERVER variable
|
||||||
*/
|
*/
|
||||||
public function __construct(ConfigFileManager $configFileManager, Cache $configCache)
|
public function __construct(ConfigFileManager $configFileManager, Cache $configCache, array $server = [])
|
||||||
{
|
{
|
||||||
$this->configFileManager = $configFileManager;
|
$this->configFileManager = $configFileManager;
|
||||||
$this->configCache = $configCache;
|
$this->configCache = $configCache;
|
||||||
|
$this->server = $server;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -56,24 +63,36 @@ class Config implements IManageConfigValues
|
||||||
return $this->configCache;
|
return $this->configCache;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
public function save()
|
public function save()
|
||||||
{
|
{
|
||||||
$this->configFileManager->saveData($this->configCache);
|
try {
|
||||||
|
$this->configFileManager->saveData($this->configCache);
|
||||||
|
} catch (ConfigFileException $e) {
|
||||||
|
throw new ConfigPersistenceException('Cannot save config', $e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function load(string $cat = 'config')
|
/** {@inheritDoc} */
|
||||||
|
public function reload()
|
||||||
{
|
{
|
||||||
$configCache = new Cache();
|
$configCache = new Cache();
|
||||||
|
|
||||||
$this->configFileManager->setupCache($configCache, $_SERVER);
|
try {
|
||||||
|
$this->configFileManager->setupCache($configCache, $this->server);
|
||||||
|
} catch (ConfigFileException $e) {
|
||||||
|
throw new ConfigPersistenceException('Cannot reload config', $e);
|
||||||
|
}
|
||||||
$this->configCache = $configCache;
|
$this->configCache = $configCache;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get(string $cat, string $key, $default_value = null, bool $refresh = false)
|
/** {@inheritDoc} */
|
||||||
|
public function get(string $cat, string $key, $default_value = null)
|
||||||
{
|
{
|
||||||
return $this->configCache->get($cat, $key) ?? $default_value;
|
return $this->configCache->get($cat, $key) ?? $default_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
public function set(string $cat, string $key, $value, bool $autosave = true): bool
|
public function set(string $cat, string $key, $value, bool $autosave = true): bool
|
||||||
{
|
{
|
||||||
$stored = $this->configCache->set($cat, $key, $value, Cache::SOURCE_DATA);
|
$stored = $this->configCache->set($cat, $key, $value, Cache::SOURCE_DATA);
|
||||||
|
@ -85,6 +104,7 @@ class Config implements IManageConfigValues
|
||||||
return $stored;
|
return $stored;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
public function delete(string $cat, string $key, bool $autosave = true): bool
|
public function delete(string $cat, string $key, bool $autosave = true): bool
|
||||||
{
|
{
|
||||||
$removed = $this->configCache->delete($cat, $key);
|
$removed = $this->configCache->delete($cat, $key);
|
||||||
|
|
|
@ -54,7 +54,7 @@ class Update
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't check the status if the last update was failed
|
// Don't check the status if the last update was failed
|
||||||
if (DI::config()->get('system', 'update', Update::SUCCESS, true) == Update::FAILED) {
|
if (DI::config()->get('system', 'update', Update::SUCCESS) == Update::FAILED) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,7 +119,7 @@ class Update
|
||||||
DI::lock()->release('dbupdate', true);
|
DI::lock()->release('dbupdate', true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$build = DI::config()->get('system', 'build', null, true);
|
$build = DI::config()->get('system', 'build', null);
|
||||||
|
|
||||||
if (empty($build) || ($build > DB_UPDATE_VERSION)) {
|
if (empty($build) || ($build > DB_UPDATE_VERSION)) {
|
||||||
$build = DB_UPDATE_VERSION - 1;
|
$build = DB_UPDATE_VERSION - 1;
|
||||||
|
@ -132,7 +132,7 @@ class Update
|
||||||
$stored = intval($build);
|
$stored = intval($build);
|
||||||
$current = intval(DB_UPDATE_VERSION);
|
$current = intval(DB_UPDATE_VERSION);
|
||||||
if ($stored < $current || $force) {
|
if ($stored < $current || $force) {
|
||||||
DI::config()->load('database');
|
DI::config()->reload();
|
||||||
|
|
||||||
// Compare the current structure with the defined structure
|
// Compare the current structure with the defined structure
|
||||||
// If the Lock is acquired, never release it automatically to avoid double updates
|
// If the Lock is acquired, never release it automatically to avoid double updates
|
||||||
|
@ -141,7 +141,7 @@ class Update
|
||||||
Logger::notice('Update starting.', ['from' => $stored, 'to' => $current]);
|
Logger::notice('Update starting.', ['from' => $stored, 'to' => $current]);
|
||||||
|
|
||||||
// Checks if the build changed during Lock acquiring (so no double update occurs)
|
// Checks if the build changed during Lock acquiring (so no double update occurs)
|
||||||
$retryBuild = DI::config()->get('system', 'build', null, true);
|
$retryBuild = DI::config()->get('system', 'build', null);
|
||||||
if ($retryBuild !== $build) {
|
if ($retryBuild !== $build) {
|
||||||
Logger::notice('Update already done.', ['from' => $stored, 'to' => $current]);
|
Logger::notice('Update already done.', ['from' => $stored, 'to' => $current]);
|
||||||
DI::lock()->release('dbupdate');
|
DI::lock()->release('dbupdate');
|
||||||
|
|
|
@ -331,7 +331,7 @@ class Worker
|
||||||
$mypid = getmypid();
|
$mypid = getmypid();
|
||||||
|
|
||||||
// Quit when in maintenance
|
// Quit when in maintenance
|
||||||
if (DI::config()->get('system', 'maintenance', false, true)) {
|
if (DI::config()->get('system', 'maintenance', false)) {
|
||||||
Logger::notice('Maintenance mode - quit process', ['pid' => $mypid]);
|
Logger::notice('Maintenance mode - quit process', ['pid' => $mypid]);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -157,7 +157,7 @@ class Friendica extends BaseModule
|
||||||
|
|
||||||
$visible_addons = Addon::getVisibleList();
|
$visible_addons = Addon::getVisibleList();
|
||||||
|
|
||||||
$config->load('feature_lock');
|
$config->reload();
|
||||||
$locked_features = [];
|
$locked_features = [];
|
||||||
$featureLocks = $config->get('config', 'feature_lock');
|
$featureLocks = $config->get('config', 'feature_lock');
|
||||||
if (isset($featureLocks)) {
|
if (isset($featureLocks)) {
|
||||||
|
|
|
@ -32,7 +32,7 @@ class DBUpdate
|
||||||
public static function execute()
|
public static function execute()
|
||||||
{
|
{
|
||||||
// Just in case the last update wasn't failed
|
// Just in case the last update wasn't failed
|
||||||
if (DI::config()->get('system', 'update', Update::SUCCESS, true) != Update::FAILED) {
|
if (DI::config()->get('system', 'update', Update::SUCCESS) != Update::FAILED) {
|
||||||
Update::run(DI::app()->getBasePath());
|
Update::run(DI::app()->getBasePath());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -99,6 +99,9 @@ return [
|
||||||
],
|
],
|
||||||
Config\Capability\IManageConfigValues::class => [
|
Config\Capability\IManageConfigValues::class => [
|
||||||
'instanceOf' => Config\Model\Config::class,
|
'instanceOf' => Config\Model\Config::class,
|
||||||
|
'constructParams' => [
|
||||||
|
$_SERVER,
|
||||||
|
],
|
||||||
],
|
],
|
||||||
PConfig\Capability\IManagePersonalConfigValues::class => [
|
PConfig\Capability\IManagePersonalConfigValues::class => [
|
||||||
'instanceOf' => PConfig\Factory\PConfig::class,
|
'instanceOf' => PConfig\Factory\PConfig::class,
|
||||||
|
|
|
@ -1178,12 +1178,6 @@ function update_1505()
|
||||||
|
|
||||||
function update_1508()
|
function update_1508()
|
||||||
{
|
{
|
||||||
$categories = DBA::toArray(DBA::p("SELECT DISTINCT `cat` AS 'cat' FROM `config`"));
|
|
||||||
|
|
||||||
foreach ($categories as $category) {
|
|
||||||
DI::config()->load($category['cat']);
|
|
||||||
}
|
|
||||||
|
|
||||||
$config = DBA::selectToArray('config');
|
$config = DBA::selectToArray('config');
|
||||||
|
|
||||||
foreach ($config as $entry) {
|
foreach ($config as $entry) {
|
||||||
|
|
|
@ -49,7 +49,7 @@ $login_bg_color = '';
|
||||||
$modified = time();
|
$modified = time();
|
||||||
|
|
||||||
if (DI::mode()->has(\Friendica\App\Mode::MAINTENANCEDISABLED)) {
|
if (DI::mode()->has(\Friendica\App\Mode::MAINTENANCEDISABLED)) {
|
||||||
DI::config()->load('frio');
|
DI::config()->reload('frio');
|
||||||
|
|
||||||
// Default to hard-coded values for empty settings
|
// Default to hard-coded values for empty settings
|
||||||
$scheme = DI::config()->get('frio', 'scheme', DI::config()->get('frio', 'schema'));
|
$scheme = DI::config()->get('frio', 'scheme', DI::config()->get('frio', 'schema'));
|
||||||
|
|
Loading…
Reference in a new issue