namespace Friendica\Factory;
+use Exception;
use Friendica\Core\Config;
+use Friendica\Core\Config\Cache;
+use Friendica\Model\Config\Config as ConfigModel;
+use Friendica\Model\Config\PConfig as PConfigModel;
+use Friendica\Util\ConfigFileLoader;
class ConfigFactory
{
- public static function createCache(Config\ConfigCacheLoader $loader)
+ /**
+ * @param ConfigFileLoader $loader The Config Cache loader (INI/config/.htconfig)
+ *
+ * @return Cache
+ *
+ * @throws Exception
+ */
+ public function createCache(ConfigFileLoader $loader)
{
- $configCache = new Config\ConfigCache();
- $loader->loadConfigFiles($configCache);
+ $configCache = new Cache();
+ $loader->setupCache($configCache);
return $configCache;
}
/**
- * @param string $type The adapter type
- * @param Config\IConfigCache $config The config cache of this adapter
- * @return Config\IConfigAdapter
+ * @param Cache $configCache The config cache of this adapter
+ * @param ConfigModel $configModel The configuration model
+ *
+ * @return Config\IConfig
*/
- public static function createConfig($type, $config)
+ public function createConfig(Cache $configCache, ConfigModel $configModel)
{
- if ($type == 'preload') {
- return new Config\PreloadConfigAdapter($config);
+ if ($configCache->get('system', 'config_adapter') === 'preload') {
+ $configuration = new Config\PreloadConfig($configCache, $configModel);
} else {
- return new Config\JITConfigAdapter($config);
+ $configuration = new Config\JitConfig($configCache, $configModel);
}
+
+
+ return $configuration;
}
/**
- * @param string $type The adapter type
- * @param int $uid The UID of the current user
- * @param Config\IPConfigCache $config The config cache of this adapter
- * @return Config\IPConfigAdapter
+ * @param Cache $configCache The config cache
+ * @param \Friendica\Core\PConfig\Cache $pConfigCache The personal config cache
+ * @param PConfigModel $configModel The configuration model
+ *
+ * @return \Friendica\Core\PConfig\IPConfig
*/
- public static function createPConfig($type, $uid, $config)
+ public function createPConfig(Cache $configCache, \Friendica\Core\PConfig\Cache $pConfigCache, PConfigModel $configModel)
{
- if ($type == 'preload') {
- return new Config\PreloadPConfigAdapter($uid, $config);
+ if ($configCache->get('system', 'config_adapter') === 'preload') {
+ $configuration = new \Friendica\Core\PConfig\PreloadPConfig($pConfigCache, $configModel);
} else {
- return new Config\JITPConfigAdapter($config);
+ $configuration = new \Friendica\Core\PConfig\JitPConfig($pConfigCache, $configModel);
}
+
+ return $configuration;
}
}