use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\Config;
-use Friendica\Core\Hooks\Capabilities\ICanManageInstances;
-use Friendica\Core\Hooks\Model\InstanceManager;
+use Friendica\Core\Hooks\Capability\ICanCreateInstances;
+use Friendica\Core\Hooks\Capability\ICanRegisterStrategies;
+use Friendica\Core\Hooks\Model\DiceInstanceManager;
use Friendica\Core\PConfig;
use Friendica\Core\L10n;
use Friendica\Core\Lock;
// one instance for the whole execution
'shared' => true,
],
+ \Friendica\Core\Addon\Capability\ICanLoadAddons::class => [
+ 'instanceOf' => \Friendica\Core\Addon\Model\AddonLoader::class,
+ 'constructParams' => [
+ [Dice::INSTANCE => '$basepath'],
+ [Dice::INSTANCE => Dice::SELF],
+ ],
+ ],
'$basepath' => [
'instanceOf' => Util\BasePath::class,
'call' => [
$_SERVER
]
],
- ICanManageInstances::class => [
- 'instanceOf' => InstanceManager::class,
+ DiceInstanceManager::class => [
+ 'constructParams' => [
+ [Dice::INSTANCE => Dice::SELF],
+ ]
+ ],
+ \Friendica\Core\Hooks\Util\StrategiesFileManager::class => [
+ 'constructParams' => [
+ [Dice::INSTANCE => '$basepath'],
+ ],
+ 'call' => [
+ ['loadConfig'],
+ ],
+ ],
+ ICanRegisterStrategies::class => [
+ 'instanceOf' => DiceInstanceManager::class,
+ 'constructParams' => [
+ [Dice::INSTANCE => Dice::SELF],
+ ],
+ ],
+ ICanCreateInstances::class => [
+ 'instanceOf' => DiceInstanceManager::class,
'constructParams' => [
[Dice::INSTANCE => Dice::SELF],
],
],
],
Config\Capability\IManageConfigValues::class => [
- 'instanceOf' => Config\Model\Config::class,
+ 'instanceOf' => Config\Model\DatabaseConfig::class,
'constructParams' => [
$_SERVER,
],
],
Database::class => [
'constructParams' => [
- [Dice::INSTANCE => \Psr\Log\NullLogger::class],
+ [Dice::INSTANCE => Config\Model\ReadOnlyFileConfig::class],
],
],
/**
$_SERVER,
],
],
+ '$hostname' => [
+ 'instanceOf' => App\BaseURL::class,
+ 'constructParams' => [
+ $_SERVER,
+ ],
+ 'call' => [
+ ['getHost', [], Dice::CHAIN_CALL],
+ ],
+ ],
+ Cache\Type\AbstractCache::class => [
+ 'constructParams' => [
+ [Dice::INSTANCE => '$hostname'],
+ ],
+ ],
App\Page::class => [
'constructParams' => [
[Dice::INSTANCE => '$basepath'],
],
],
- /**
- * Create a Logger, which implements the LoggerInterface
- *
- * Same as:
- * $loggerFactory = new Factory\LoggerFactory();
- * $logger = $loggerFactory->create($channel, $configuration, $profiler);
- *
- * Attention1: We can use DICE for detecting dependencies inside "chained" calls too
- * Attention2: The variable "$channel" is passed inside the creation of the dependencies per:
- * $app = $dice->create(App::class, [], ['$channel' => 'index']);
- * and is automatically passed as an argument with the same name
- */
- LoggerInterface::class => [
+ \Psr\Log\LoggerInterface::class => [
'instanceOf' => \Friendica\Core\Logger\Factory\Logger::class,
- 'constructParams' => [
- 'index',
+ 'call' => [
+ ['create', [], Dice::CHAIN_CALL],
+ ],
+ ],
+ \Friendica\Core\Logger\Type\SyslogLogger::class => [
+ 'instanceOf' => \Friendica\Core\Logger\Factory\SyslogLogger::class,
+ 'call' => [
+ ['create', [], Dice::CHAIN_CALL],
],
+ ],
+ \Friendica\Core\Logger\Type\StreamLogger::class => [
+ 'instanceOf' => \Friendica\Core\Logger\Factory\StreamLogger::class,
'call' => [
['create', [], Dice::CHAIN_CALL],
],
],
- '$devLogger' => [
- 'instanceOf' => \Friendica\Core\Logger\Factory\Logger::class,
+ \Friendica\Core\Logger\Capability\IHaveCallIntrospections::class => [
+ 'instanceOf' => \Friendica\Core\Logger\Util\Introspection::class,
'constructParams' => [
- 'dev',
+ \Friendica\Core\Logger\Capability\IHaveCallIntrospections::IGNORE_CLASS_LIST,
],
+ ],
+ '$devLogger' => [
+ 'instanceOf' => \Friendica\Core\Logger\Factory\StreamLogger::class,
'call' => [
['createDev', [], Dice::CHAIN_CALL],
- ]
- ],
- \Friendica\Core\Logger\Capabilities\IHaveCallIntrospections::class => [
- 'instanceOf' => \Friendica\Core\Logger\Util\Introspection::class,
- 'constructParams' => [
- \Friendica\Core\Logger\Util\Introspection::IGNORE_CLASS_LIST,
],
],
Cache\Capability\ICanCache::class => [
IHandleSessions::class => [
'instanceOf' => \Friendica\Core\Session\Factory\Session::class,
'call' => [
- ['createSession', [$_SERVER], Dice::CHAIN_CALL],
+ ['create', [$_SERVER], Dice::CHAIN_CALL],
['start', [], Dice::CHAIN_CALL],
],
],
['getBackend', [], Dice::CHAIN_CALL],
],
],
- \Friendica\Core\KeyValueStorage\Capabilities\IManageKeyValuePairs::class => [
- 'instanceOf' => \Friendica\Core\KeyValueStorage\Type\DBKeyValueStorage::class,
+ \Friendica\Core\KeyValueStorage\Capability\IManageKeyValuePairs::class => [
+ 'instanceOf' => \Friendica\Core\KeyValueStorage\Factory\KeyValueStorage::class,
+ 'call' => [
+ ['create', [], Dice::CHAIN_CALL],
+ ],
],
Network\HTTPClient\Capability\ICanSendHttpRequests::class => [
'instanceOf' => Network\HTTPClient\Factory\HttpClient::class,