2019-12-15 22:34:11 +01:00
|
|
|
<?php
|
2020-02-09 15:45:36 +01:00
|
|
|
/**
|
2021-03-29 08:40:20 +02:00
|
|
|
* @copyright Copyright (C) 2010-2021, the Friendica project
|
2020-02-09 15:45:36 +01:00
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
2019-12-15 22:34:11 +01:00
|
|
|
|
|
|
|
namespace Friendica;
|
|
|
|
|
|
|
|
use Dice\Dice;
|
2019-12-15 23:28:01 +01:00
|
|
|
use Psr\Log\LoggerInterface;
|
2019-12-15 22:34:11 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This class is capable of getting all dynamic created classes
|
|
|
|
*
|
2020-01-18 11:28:29 +01:00
|
|
|
* @see https://designpatternsphp.readthedocs.io/en/latest/Structural/Registry/README.html
|
2019-12-15 22:34:11 +01:00
|
|
|
*/
|
2019-12-22 21:25:29 +01:00
|
|
|
abstract class DI
|
2019-12-15 22:34:11 +01:00
|
|
|
{
|
|
|
|
/** @var Dice */
|
|
|
|
private static $dice;
|
|
|
|
|
|
|
|
public static function init(Dice $dice)
|
|
|
|
{
|
|
|
|
self::$dice = $dice;
|
|
|
|
}
|
|
|
|
|
2021-08-23 15:47:41 +02:00
|
|
|
/**
|
|
|
|
* Returns a clone of the current dice instance
|
|
|
|
* This usefull for overloading the current instance with mocked methods during tests
|
|
|
|
*
|
|
|
|
* @return Dice
|
|
|
|
*/
|
|
|
|
public static function getDice()
|
|
|
|
{
|
|
|
|
return clone self::$dice;
|
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
//
|
|
|
|
// common instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return App
|
|
|
|
*/
|
|
|
|
public static function app()
|
|
|
|
{
|
|
|
|
return self::$dice->create(App::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Database\Database
|
|
|
|
*/
|
|
|
|
public static function dba()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Database\Database::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// "App" namespace instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return App\Arguments
|
|
|
|
*/
|
|
|
|
public static function args()
|
|
|
|
{
|
|
|
|
return self::$dice->create(App\Arguments::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return App\BaseURL
|
|
|
|
*/
|
|
|
|
public static function baseUrl()
|
|
|
|
{
|
|
|
|
return self::$dice->create(App\BaseURL::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return App\Mode
|
|
|
|
*/
|
|
|
|
public static function mode()
|
|
|
|
{
|
|
|
|
return self::$dice->create(App\Mode::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return App\Module
|
|
|
|
*/
|
|
|
|
public static function module()
|
|
|
|
{
|
|
|
|
return self::$dice->create(App\Module::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return App\Page
|
|
|
|
*/
|
|
|
|
public static function page()
|
|
|
|
{
|
|
|
|
return self::$dice->create(App\Page::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return App\Router
|
|
|
|
*/
|
|
|
|
public static function router()
|
|
|
|
{
|
|
|
|
return self::$dice->create(App\Router::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// "Content" namespace instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Content\Item
|
|
|
|
*/
|
|
|
|
public static function contentItem()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Content\Item::class);
|
|
|
|
}
|
|
|
|
|
2021-09-23 23:18:36 +02:00
|
|
|
/**
|
|
|
|
* @return Content\Conversation
|
|
|
|
*/
|
|
|
|
public static function conversation()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Content\Conversation::class);
|
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
/**
|
|
|
|
* @return Content\Text\BBCode\Video
|
|
|
|
*/
|
|
|
|
public static function bbCodeVideo()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Content\Text\BBCode\Video::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// "Core" namespace instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
2021-10-26 22:09:11 +02:00
|
|
|
* @return Core\Cache\Capability\ICanCache
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function cache()
|
|
|
|
{
|
2021-10-26 21:44:29 +02:00
|
|
|
return self::$dice->create(Core\Cache\Capability\ICanCache::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-10-26 22:09:11 +02:00
|
|
|
* @return Core\Config\Capability\IManageConfigValues
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function config()
|
|
|
|
{
|
2021-10-26 21:44:29 +02:00
|
|
|
return self::$dice->create(Core\Config\Capability\IManageConfigValues::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-10-26 22:09:11 +02:00
|
|
|
* @return Core\PConfig\Capability\IManagePersonalConfigValues
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function pConfig()
|
|
|
|
{
|
2021-10-26 21:44:29 +02:00
|
|
|
return self::$dice->create(Core\PConfig\Capability\IManagePersonalConfigValues::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-10-26 22:09:11 +02:00
|
|
|
* @return Core\Lock\Capability\ICanLock
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function lock()
|
|
|
|
{
|
2021-10-26 21:44:29 +02:00
|
|
|
return self::$dice->create(Core\Lock\Capability\ICanLock::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
2020-01-18 21:01:44 +01:00
|
|
|
/**
|
2020-01-18 22:07:07 +01:00
|
|
|
* @return Core\L10n
|
2020-01-18 21:01:44 +01:00
|
|
|
*/
|
2020-01-18 11:28:29 +01:00
|
|
|
public static function l10n()
|
|
|
|
{
|
2020-01-18 20:59:39 +01:00
|
|
|
return self::$dice->create(Core\L10n::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Core\Process
|
|
|
|
*/
|
|
|
|
public static function process()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Core\Process::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-10-26 22:09:11 +02:00
|
|
|
* @return Core\Session\Capability\IHandleSessions
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function session()
|
|
|
|
{
|
2021-10-26 21:44:29 +02:00
|
|
|
return self::$dice->create(Core\Session\Capability\IHandleSessions::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-10-23 12:11:38 +02:00
|
|
|
* @return \Friendica\Core\Storage\Repository\StorageManager
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function storageManager()
|
|
|
|
{
|
2021-10-23 12:11:38 +02:00
|
|
|
return self::$dice->create(Core\Storage\Repository\StorageManager::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// "LoggerInterface" instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return LoggerInterface
|
|
|
|
*/
|
|
|
|
public static function logger()
|
|
|
|
{
|
|
|
|
return self::$dice->create(LoggerInterface::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return LoggerInterface
|
|
|
|
*/
|
|
|
|
public static function devLogger()
|
|
|
|
{
|
|
|
|
return self::$dice->create('$devLogger');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return LoggerInterface
|
|
|
|
*/
|
|
|
|
public static function workerLogger()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Util\Logger\WorkerLogger::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// "Factory" namespace instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
2020-01-28 13:33:37 +01:00
|
|
|
* @return Factory\Api\Mastodon\Account
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function mstdnAccount()
|
|
|
|
{
|
2020-01-28 13:33:37 +01:00
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Account::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
2021-05-10 00:23:21 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Application
|
|
|
|
*/
|
|
|
|
public static function mstdnApplication()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Application::class);
|
|
|
|
}
|
|
|
|
|
2020-10-31 17:09:27 +01:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Attachment
|
|
|
|
*/
|
|
|
|
public static function mstdnAttachment()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Attachment::class);
|
|
|
|
}
|
|
|
|
|
2021-05-11 21:15:05 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Card
|
|
|
|
*/
|
|
|
|
public static function mstdnCard()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Card::class);
|
|
|
|
}
|
|
|
|
|
2021-05-19 23:56:50 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Conversation
|
|
|
|
*/
|
|
|
|
public static function mstdnConversation()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Conversation::class);
|
|
|
|
}
|
|
|
|
|
2020-01-28 03:33:51 +01:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Emoji
|
|
|
|
*/
|
|
|
|
public static function mstdnEmoji()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Emoji::class);
|
|
|
|
}
|
|
|
|
|
2020-10-31 23:32:26 +01:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Error
|
|
|
|
*/
|
|
|
|
public static function mstdnError()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Error::class);
|
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
/**
|
2020-01-28 13:33:37 +01:00
|
|
|
* @return Factory\Api\Mastodon\FollowRequest
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function mstdnFollowRequest()
|
|
|
|
{
|
2020-01-28 13:33:37 +01:00
|
|
|
return self::$dice->create(Factory\Api\Mastodon\FollowRequest::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2020-01-28 13:33:37 +01:00
|
|
|
* @return Factory\Api\Mastodon\Relationship
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function mstdnRelationship()
|
|
|
|
{
|
2020-01-28 13:33:37 +01:00
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Relationship::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
2020-09-03 20:57:18 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Status
|
|
|
|
*/
|
|
|
|
public static function mstdnStatus()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Status::class);
|
|
|
|
}
|
|
|
|
|
2021-07-29 12:34:31 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\ScheduledStatus
|
|
|
|
*/
|
|
|
|
public static function mstdnScheduledStatus()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\ScheduledStatus::class);
|
|
|
|
}
|
|
|
|
|
2021-08-15 02:30:41 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Subscription
|
|
|
|
*/
|
|
|
|
public static function mstdnSubscription()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Subscription::class);
|
|
|
|
}
|
|
|
|
|
2021-05-09 11:35:51 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\ListEntity
|
|
|
|
*/
|
|
|
|
public static function mstdnList()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\ListEntity::class);
|
|
|
|
}
|
|
|
|
|
2021-05-09 13:50:05 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Mastodon\Notification
|
|
|
|
*/
|
|
|
|
public static function mstdnNotification()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Mastodon\Notification::class);
|
|
|
|
}
|
|
|
|
|
2020-05-10 07:04:18 +02:00
|
|
|
/**
|
|
|
|
* @return Factory\Api\Twitter\User
|
|
|
|
*/
|
|
|
|
public static function twitterUser()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Factory\Api\Twitter\User::class);
|
|
|
|
}
|
|
|
|
|
2021-09-18 05:41:02 +02:00
|
|
|
public static function notificationIntro(): Navigation\Notifications\Factory\Introduction
|
2020-01-25 02:01:49 +01:00
|
|
|
{
|
2021-09-18 05:41:02 +02:00
|
|
|
return self::$dice->create(Navigation\Notifications\Factory\Introduction::class);
|
2020-01-25 02:01:49 +01:00
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
//
|
|
|
|
// "Model" namespace instances
|
|
|
|
//
|
2020-09-15 18:16:44 +02:00
|
|
|
/**
|
|
|
|
* @return Model\Process
|
|
|
|
*/
|
|
|
|
public static function modelProcess()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Model\Process::class);
|
|
|
|
}
|
2020-01-18 11:28:29 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Model\User\Cookie
|
|
|
|
*/
|
|
|
|
public static function cookie()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Model\User\Cookie::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-10-23 12:11:38 +02:00
|
|
|
* @return Core\Storage\Capability\ICanWriteToStorage
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function storage()
|
|
|
|
{
|
2021-10-23 12:11:38 +02:00
|
|
|
return self::$dice->create(Core\Storage\Capability\ICanWriteToStorage::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
2021-08-19 13:03:45 +02:00
|
|
|
/**
|
|
|
|
* @return Model\Log\ParsedLogIterator
|
|
|
|
*/
|
|
|
|
public static function parsedLogIterator()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Model\Log\ParsedLogIterator::class);
|
|
|
|
}
|
|
|
|
|
2020-03-04 22:11:01 +01:00
|
|
|
//
|
|
|
|
// "Network" namespace
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
2021-08-23 00:14:18 +02:00
|
|
|
* @return Network\IHTTPClient
|
2020-03-04 22:11:01 +01:00
|
|
|
*/
|
2021-08-25 21:54:54 +02:00
|
|
|
public static function httpClient()
|
2020-03-04 22:11:01 +01:00
|
|
|
{
|
2021-08-23 00:14:18 +02:00
|
|
|
return self::$dice->create(Network\IHTTPClient::class);
|
2020-03-04 22:11:01 +01:00
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
//
|
|
|
|
// "Repository" namespace
|
|
|
|
//
|
|
|
|
|
2020-01-31 23:50:46 +01:00
|
|
|
/**
|
2021-10-21 23:18:08 +02:00
|
|
|
* @return Contact\FriendSuggest\Repository\FriendSuggest;
|
2020-01-31 23:50:46 +01:00
|
|
|
*/
|
|
|
|
public static function fsuggest()
|
|
|
|
{
|
2021-10-21 23:18:08 +02:00
|
|
|
return self::$dice->create(Contact\FriendSuggest\Repository\FriendSuggest::class);
|
2021-10-21 22:57:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Contact\FriendSuggest\Factory\FriendSuggest;
|
|
|
|
*/
|
|
|
|
public static function fsuggestFactory()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Contact\FriendSuggest\Factory\FriendSuggest::class);
|
2020-01-31 23:50:46 +01:00
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
/**
|
2021-10-21 23:18:08 +02:00
|
|
|
* @return Contact\Introduction\Repository\Introduction
|
2020-01-18 11:28:29 +01:00
|
|
|
*/
|
|
|
|
public static function intro()
|
|
|
|
{
|
2021-10-21 23:18:08 +02:00
|
|
|
return self::$dice->create(Contact\Introduction\Repository\Introduction::class);
|
2020-01-18 11:28:29 +01:00
|
|
|
}
|
|
|
|
|
2021-10-18 22:49:25 +02:00
|
|
|
/**
|
|
|
|
* @return Contact\Introduction\Factory\Introduction
|
|
|
|
*/
|
|
|
|
public static function introFactory()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Contact\Introduction\Factory\Introduction::class);
|
|
|
|
}
|
|
|
|
|
2021-10-21 23:18:08 +02:00
|
|
|
public static function permissionSet(): Security\PermissionSet\Repository\PermissionSet
|
2020-01-14 04:20:18 +01:00
|
|
|
{
|
2021-10-21 23:18:08 +02:00
|
|
|
return self::$dice->create(Security\PermissionSet\Repository\PermissionSet::class);
|
2021-10-05 23:30:10 +02:00
|
|
|
}
|
|
|
|
|
2021-10-07 19:46:24 +02:00
|
|
|
public static function permissionSetFactory(): Security\PermissionSet\Factory\PermissionSet
|
2021-10-05 23:30:10 +02:00
|
|
|
{
|
2021-10-07 19:46:24 +02:00
|
|
|
return self::$dice->create(Security\PermissionSet\Factory\PermissionSet::class);
|
2020-01-14 04:20:18 +01:00
|
|
|
}
|
|
|
|
|
2021-10-21 23:18:08 +02:00
|
|
|
public static function profileField(): Profile\ProfileField\Repository\ProfileField
|
2021-10-08 19:45:20 +02:00
|
|
|
{
|
2021-10-21 23:18:08 +02:00
|
|
|
return self::$dice->create(Profile\ProfileField\Repository\ProfileField::class);
|
2021-10-08 19:45:20 +02:00
|
|
|
}
|
|
|
|
|
2021-10-10 20:39:35 +02:00
|
|
|
public static function profileFieldFactory(): Profile\ProfileField\Factory\ProfileField
|
|
|
|
{
|
|
|
|
return self::$dice->create(Profile\ProfileField\Factory\ProfileField::class);
|
|
|
|
}
|
|
|
|
|
2021-10-21 23:18:08 +02:00
|
|
|
public static function notification(): Navigation\Notifications\Repository\Notification
|
2021-09-18 06:03:32 +02:00
|
|
|
{
|
2021-10-21 23:18:08 +02:00
|
|
|
return self::$dice->create(Navigation\Notifications\Repository\Notification::class);
|
2021-09-18 06:03:32 +02:00
|
|
|
}
|
|
|
|
|
2021-09-19 18:56:24 +02:00
|
|
|
public static function notificationFactory(): Navigation\Notifications\Factory\Notification
|
|
|
|
{
|
|
|
|
return self::$dice->create(Navigation\Notifications\Factory\Notification::class);
|
|
|
|
}
|
|
|
|
|
2021-10-21 23:18:08 +02:00
|
|
|
public static function notify(): Navigation\Notifications\Repository\Notify
|
2020-01-28 21:28:57 +01:00
|
|
|
{
|
2021-10-21 23:18:08 +02:00
|
|
|
return self::$dice->create(Navigation\Notifications\Repository\Notify::class);
|
2020-01-28 21:28:57 +01:00
|
|
|
}
|
|
|
|
|
2021-09-19 18:56:24 +02:00
|
|
|
public static function notifyFactory(): Navigation\Notifications\Factory\Notify
|
|
|
|
{
|
|
|
|
return self::$dice->create(Navigation\Notifications\Factory\Notify::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function formattedNotificationFactory(): Navigation\Notifications\Factory\FormattedNotification
|
|
|
|
{
|
|
|
|
return self::$dice->create(Navigation\Notifications\Factory\FormattedNotification::class);
|
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
//
|
|
|
|
// "Protocol" namespace instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Protocol\Activity
|
|
|
|
*/
|
|
|
|
public static function activity()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Protocol\Activity::class);
|
|
|
|
}
|
|
|
|
|
2020-09-30 16:53:18 +02:00
|
|
|
//
|
|
|
|
// "Security" namespace instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return \Friendica\Security\Authentication
|
|
|
|
*/
|
|
|
|
public static function auth()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Security\Authentication::class);
|
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
//
|
|
|
|
// "Util" namespace instances
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Util\ACLFormatter
|
|
|
|
*/
|
|
|
|
public static function aclFormatter()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Util\ACLFormatter::class);
|
|
|
|
}
|
|
|
|
|
2020-04-26 15:45:25 +02:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function basePath()
|
|
|
|
{
|
|
|
|
return self::$dice->create('$basepath');
|
|
|
|
}
|
|
|
|
|
2020-01-18 11:28:29 +01:00
|
|
|
/**
|
|
|
|
* @return Util\DateTimeFormat
|
|
|
|
*/
|
|
|
|
public static function dtFormat()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Util\DateTimeFormat::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Util\FileSystem
|
|
|
|
*/
|
|
|
|
public static function fs()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Util\FileSystem::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Util\Profiler
|
|
|
|
*/
|
|
|
|
public static function profiler()
|
2019-12-15 22:34:11 +01:00
|
|
|
{
|
2020-01-18 11:28:29 +01:00
|
|
|
return self::$dice->create(Util\Profiler::class);
|
2019-12-15 22:34:11 +01:00
|
|
|
}
|
2020-01-25 23:10:39 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Util\Emailer
|
|
|
|
*/
|
|
|
|
public static function emailer()
|
|
|
|
{
|
|
|
|
return self::$dice->create(Util\Emailer::class);
|
|
|
|
}
|
2019-12-15 22:34:11 +01:00
|
|
|
}
|