use Friendica\Core\L10n;
use Friendica\Core\System;
use Friendica\Database\Database;
+use Friendica\Factory\Api\Mastodon\Account as AccountFactory;
+use Friendica\Model\User;
use Friendica\Module\Api\ApiResponse;
use Friendica\Module\BaseApi;
use Friendica\Object\Api\Mastodon\Instance as InstanceEntity;
/** @var IManageConfigValues */
private $config;
- public function __construct(\Friendica\Factory\Api\Mastodon\Error $errorFactory, App $app, L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, ApiResponse $response, Database $database, IManageConfigValues $config, array $server, array $parameters = [])
+ /** @var AccountFactory */
+ private $accountFactory;
+
+ public function __construct(AccountFactory $accountFactory, \Friendica\Factory\Api\Mastodon\Error $errorFactory, App $app, L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, ApiResponse $response, Database $database, IManageConfigValues $config, array $server, array $parameters = [])
{
parent::__construct($errorFactory, $app, $l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
$this->database = $database;
$this->config = $config;
+ $this->accountFactory = $accountFactory;
}
/**
*/
protected function rawContent(array $request = [])
{
- $this->jsonExit(new InstanceEntity($this->config, $this->baseUrl, $this->database, System::getRules(), $this->buildConfigurationInfo()));
+ $administrator = User::getFirstAdmin(['nickname']);
+ if ($administrator) {
+ $adminContact = $this->database->selectFirst('contact', ['uri-id'], ['nick' => $administrator['nickname'], 'self' => true]);
+ $contact_account = $this->accountFactory->createFromUriId($adminContact['uri-id']);
+ }
+
+ $this->jsonExit(new InstanceEntity($this->config, $this->baseUrl, $this->database, $this->buildConfigurationInfo(), $contact_account ?? null, System::getRules()));
}
private function buildConfigurationInfo(): InstanceV2Entity\Configuration
use Friendica\Contact\Header;
use Friendica\Core\Config\Capability\IManageConfigValues;
use Friendica\Database\Database;
-use Friendica\DI;
use Friendica\Model\User;
use Friendica\Module\Register;
-use Friendica\Network\HTTPException;
use Friendica\Object\Api\Mastodon\InstanceV2\Configuration;
/**
protected $approval_required;
/** @var bool */
protected $invites_enabled;
- /** @var Account|null */
/** @var Configuration */
protected $configuration;
+ /** @var Account|null */
protected $contact_account = null;
/** @var array */
protected $rules = [];
- /**
- * @param IManageConfigValues $config
- * @param BaseURL $baseUrl
- * @param Database $database
- * @param array $rules
- * @throws HTTPException\InternalServerErrorException
- * @throws HTTPException\NotFoundException
- * @throws \ImagickException
- */
- public function __construct(IManageConfigValues $config, BaseURL $baseUrl, Database $database, array $rules = [], Configuration $configuration)
+ public function __construct(IManageConfigValues $config, BaseURL $baseUrl, Database $database, Configuration $configuration, ?Account $contact_account, array $rules)
{
$register_policy = intval($config->get('config', 'register_policy'));
$this->approval_required = ($register_policy == Register::APPROVE);
$this->invites_enabled = false;
$this->configuration = $configuration;
- $this->contact_account = [];
+ $this->contact_account = $contact_account ?? [];
$this->rules = $rules;
-
- $administrator = User::getFirstAdmin(['nickname']);
- if ($administrator) {
- $adminContact = $database->selectFirst('contact', ['uri-id'], ['nick' => $administrator['nickname'], 'self' => true]);
- $this->contact_account = DI::mstdnAccount()->createFromUriId($adminContact['uri-id']);
- }
}
}