3 * @copyright Copyright (C) 2010-2021, the Friendica project
5 * @license GNU AGPL version 3 or any later version
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as
9 * published by the Free Software Foundation, either version 3 of the
10 * License, or (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Affero General Public License for more details.
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 namespace Friendica\Factory;
25 use Friendica\Core\Config;
26 use Friendica\Core\Config\Cache;
27 use Friendica\Model\Config\Config as ConfigModel;
28 use Friendica\Model\Config\PConfig as PConfigModel;
29 use Friendica\Util\ConfigFileLoader;
34 * The key of the $_SERVER variable to override the config directory
38 const CONFIG_DIR_ENV = 'FRIENDICA_CONFIG_DIR';
41 * The Sub directory of the config-files
45 const CONFIG_DIR = 'config';
48 * The Sub directory of the static config-files
52 const STATIC_DIR = 'static';
55 * @param string $basePath The basepath of FRIENDICA
56 * @param array $serer the $_SERVER array
58 * @return ConfigFileLoader
60 public function createConfigFileLoader(string $basePath, array $server = [])
62 if (!empty($server[self::CONFIG_DIR_ENV]) && is_dir($server[self::CONFIG_DIR_ENV])) {
63 $configDir = $server[self::CONFIG_DIR_ENV];
65 $configDir = $basePath . DIRECTORY_SEPARATOR . self::CONFIG_DIR;
67 $staticDir = $basePath . DIRECTORY_SEPARATOR . self::STATIC_DIR;
69 return new ConfigFileLoader($basePath, $configDir, $staticDir);
73 * @param ConfigFileLoader $loader The Config Cache loader (INI/config/.htconfig)
79 public function createCache(ConfigFileLoader $loader, array $server = [])
81 $configCache = new Cache();
82 $loader->setupCache($configCache, $server);
88 * @param Cache $configCache The config cache of this adapter
89 * @param ConfigModel $configModel The configuration model
91 * @return Config\IConfig
93 public function createConfig(Cache $configCache, ConfigModel $configModel)
95 if ($configCache->get('system', 'config_adapter') === 'preload') {
96 $configuration = new Config\PreloadConfig($configCache, $configModel);
98 $configuration = new Config\JitConfig($configCache, $configModel);
102 return $configuration;
106 * @param Cache $configCache The config cache
107 * @param \Friendica\Core\PConfig\Cache $pConfigCache The personal config cache
108 * @param PConfigModel $configModel The configuration model
110 * @return \Friendica\Core\PConfig\IPConfig
112 public function createPConfig(Cache $configCache, \Friendica\Core\PConfig\Cache $pConfigCache, PConfigModel $configModel)
114 if ($configCache->get('system', 'config_adapter') === 'preload') {
115 $configuration = new \Friendica\Core\PConfig\PreloadPConfig($pConfigCache, $configModel);
117 $configuration = new \Friendica\Core\PConfig\JitPConfig($pConfigCache, $configModel);
120 return $configuration;