]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Friendica.php
Changes:
[friendica.git] / src / Module / Friendica.php
index 6b5e05c8b36cf7d3f521e4b35762923742f49ff2..79906f937a4bee2897391ce10a8eeab4fc0a97d8 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * @copyright Copyright (C) 2010-2022, the Friendica project
+ * @copyright Copyright (C) 2010-2024, the Friendica project
  *
  * @license GNU AGPL version 3 or any later version
  *
 
 namespace Friendica\Module;
 
+use Friendica\App;
 use Friendica\BaseModule;
 use Friendica\Core\Addon;
+use Friendica\Core\Config\Capability\IManageConfigValues;
 use Friendica\Core\Hook;
+use Friendica\Core\KeyValueStorage\Capability\IManageKeyValuePairs;
+use Friendica\Core\L10n;
 use Friendica\Core\Renderer;
+use Friendica\Core\Session\Capability\IHandleUserSessions;
 use Friendica\Core\System;
 use Friendica\Database\PostUpdate;
-use Friendica\DI;
 use Friendica\Model\User;
 use Friendica\Network\HTTPException;
 use Friendica\Protocol\ActivityPub;
+use Friendica\Util\Profiler;
+use Psr\Log\LoggerInterface;
 
 /**
  * Prints information about the current node
- * Either in human readable form or in JSON
+ * Either in human-readable form or in JSON
  */
 class Friendica extends BaseModule
 {
-       protected function content(array $request = []): string
+       /** @var IManageConfigValues */
+       private $config;
+       /** @var IManageKeyValuePairs */
+       private $keyValue;
+       /** @var IHandleUserSessions */
+       private $session;
+
+       public function __construct(IHandleUserSessions $session, IManageKeyValuePairs $keyValue, IManageConfigValues $config, L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, array $server, array $parameters = [])
        {
-               $config = DI::config();
+               parent::__construct($l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
+
+               $this->config = $config;
+               $this->keyValue = $keyValue;
+               $this->session = $session;
+       }
 
+       protected function content(array $request = []): string
+       {
                $visibleAddonList = Addon::getVisibleList();
                if (!empty($visibleAddonList)) {
 
@@ -59,29 +79,30 @@ class Friendica extends BaseModule
                                }
                        }
                        $addon = [
-                               'title' => DI::l10n()->t('Installed addons/apps:'),
+                               'title' => $this->t('Installed addons/apps:'),
                                'list'  => $sortedAddonList,
                        ];
                } else {
                        $addon = [
-                               'title' => DI::l10n()->t('No installed addons/apps'),
+                               'title' => $this->t('No installed addons/apps'),
                        ];
                }
 
-               $tos = ($config->get('system', 'tosdisplay')) ?
-                       DI::l10n()->t('Read about the <a href="%1$s/tos">Terms of Service</a> of this node.', DI::baseUrl()->get()) :
+               $tos = ($this->config->get('system', 'tosdisplay')) ?
+                       $this->t('Read about the <a href="%1$s/tos">Terms of Service</a> of this node.', $this->baseUrl) :
                        '';
 
-               $blockList = $config->get('system', 'blocklist');
+               $blockList = $this->config->get('system', 'blocklist') ?? [];
 
-               if (!empty($blockList)) {
+               if (!empty($blockList) && ($this->config->get('blocklist', 'public') || $this->session->isAuthenticated())) {
                        $blocked = [
-                               'title'  => DI::l10n()->t('On this server the following remote servers are blocked.'),
-                               'header' => [
-                                       DI::l10n()->t('Blocked domain'),
-                                       DI::l10n()->t('Reason for the block'),
+                               'title'    => $this->t('On this server the following remote servers are blocked.'),
+                               'header'   => [
+                                       $this->t('Blocked domain'),
+                                       $this->t('Reason for the block'),
                                ],
-                               'list'   => $blockList,
+                               'download' => $this->t('Download this list in CSV format'),
+                               'list'     => $blockList,
                        ];
                } else {
                        $blocked = null;
@@ -94,14 +115,14 @@ class Friendica extends BaseModule
                $tpl = Renderer::getMarkupTemplate('friendica.tpl');
 
                return Renderer::replaceMacros($tpl, [
-                       'about'     => DI::l10n()->t('This is Friendica, version %s that is running at the web location %s. The database version is %s, the post update version is %s.',
-                               '<strong>' . FRIENDICA_VERSION . '</strong>',
-                               DI::baseUrl()->get(),
-                               '<strong>' . $config->get('system', 'build') . '/' . DB_UPDATE_VERSION . '</strong>',
-                               '<strong>' . $config->get('system', 'post_update_version') . '/' . PostUpdate::VERSION . '</strong>'),
-                       'friendica' => DI::l10n()->t('Please visit <a href="https://friendi.ca">Friendi.ca</a> to learn more about the Friendica project.'),
-                       'bugs'      => DI::l10n()->t('Bug reports and issues: please visit') . ' ' . '<a href="https://github.com/friendica/friendica/issues?state=open">' . DI::l10n()->t('the bugtracker at github') . '</a>',
-                       'info'      => DI::l10n()->t('Suggestions, praise, etc. - please email "info" at "friendi - dot - ca'),
+                       'about'     => $this->t('This is Friendica, version %s that is running at the web location %s. The database version is %s, the post update version is %s.',
+                               '<strong>' . App::VERSION . '</strong>',
+                               $this->baseUrl,
+                               '<strong>' . $this->config->get('system', 'build') . '/' . DB_UPDATE_VERSION . '</strong>',
+                               '<strong>' . $this->keyValue->get('post_update_version') . '/' . PostUpdate::VERSION . '</strong>'),
+                       'friendica' => $this->t('Please visit <a href="https://friendi.ca">Friendi.ca</a> to learn more about the Friendica project.'),
+                       'bugs'      => $this->t('Bug reports and issues: please visit') . ' ' . '<a href="https://github.com/friendica/friendica/issues?state=open">' . $this->t('the bugtracker at github') . '</a>',
+                       'info'      => $this->t('Suggestions, praise, etc. - please email "info" at "friendi - dot - ca'),
 
                        'visible_addons' => $addon,
                        'tos'            => $tos,
@@ -112,8 +133,7 @@ class Friendica extends BaseModule
 
        protected function rawContent(array $request = [])
        {
-               // @TODO: Replace with parameter from router
-               if (DI::args()->getArgc() <= 1 || (DI::args()->getArgv()[1] !== 'json')) {
+               if (empty($this->parameters['format']) || $this->parameters['format'] !== 'json') {
                        if (!ActivityPub::isRequest()) {
                                return;
                        }
@@ -122,22 +142,20 @@ class Friendica extends BaseModule
                                $data = ActivityPub\Transmitter::getProfile(0);
                                header('Access-Control-Allow-Origin: *');
                                header('Cache-Control: max-age=23200, stale-while-revalidate=23200');
-                               System::jsonExit($data, 'application/activity+json');
+                               $this->jsonExit($data, 'application/activity+json');
                        } catch (HTTPException\NotFoundException $e) {
-                               System::jsonError(404, ['error' => 'Record not found']);
+                               $this->jsonError(404, ['error' => 'Record not found']);
                        }
                }
 
-               $config = DI::config();
-
                $register_policies = [
                        Register::CLOSED  => 'REGISTER_CLOSED',
                        Register::APPROVE => 'REGISTER_APPROVE',
                        Register::OPEN    => 'REGISTER_OPEN'
                ];
 
-               $register_policy_int = intval($config->get('config', 'register_policy'));
-               if ($register_policy_int !== Register::CLOSED && $config->get('config', 'invitation_only')) {
+               $register_policy_int = $this->config->get('config', 'register_policy');
+               if ($register_policy_int !== Register::CLOSED && $this->config->get('config', 'invitation_only')) {
                        $register_policy = 'REGISTER_INVITATION';
                } else {
                        $register_policy = $register_policies[$register_policy_int];
@@ -148,15 +166,15 @@ class Friendica extends BaseModule
                if (!empty($administrator)) {
                        $admin = [
                                'name'    => $administrator['username'],
-                               'profile' => DI::baseUrl()->get() . '/profile/' . $administrator['nickname'],
+                               'profile' => $this->baseUrl . '/profile/' . $administrator['nickname'],
                        ];
                }
 
                $visible_addons = Addon::getVisibleList();
 
-               $config->load('feature_lock');
+               $this->config->reload();
                $locked_features = [];
-               $featureLocks = $config->get('config', 'feature_lock');
+               $featureLocks = $this->config->get('config', 'feature_lock');
                if (isset($featureLocks)) {
                        foreach ($featureLocks as $feature => $lock) {
                                if ($feature === 'config_loaded') {
@@ -168,20 +186,20 @@ class Friendica extends BaseModule
                }
 
                $data = [
-                       'version'          => FRIENDICA_VERSION,
-                       'url'              => DI::baseUrl()->get(),
+                       'version'          => App::VERSION,
+                       'url'              => (string)$this->baseUrl,
                        'addons'           => $visible_addons,
                        'locked_features'  => $locked_features,
-                       'explicit_content' => intval($config->get('system', 'explicit_content', 0)),
-                       'language'         => $config->get('system', 'language'),
+                       'explicit_content' => intval($this->config->get('system', 'explicit_content', 0)),
+                       'language'         => $this->config->get('system', 'language'),
                        'register_policy'  => $register_policy,
                        'admin'            => $admin,
-                       'site_name'        => $config->get('config', 'sitename'),
-                       'platform'         => strtolower(FRIENDICA_PLATFORM),
-                       'info'             => $config->get('config', 'info'),
-                       'no_scrape_url'    => DI::baseUrl()->get() . '/noscrape',
+                       'site_name'        => $this->config->get('config', 'sitename'),
+                       'platform'         => strtolower(App::PLATFORM),
+                       'info'             => $this->config->get('config', 'info'),
+                       'no_scrape_url'    => $this->baseUrl . '/noscrape',
                ];
 
-               System::jsonExit($data);
+               $this->jsonExit($data);
        }
 }