]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Profile/Index.php
Merge pull request #13238 from annando/issue-13221
[friendica.git] / src / Module / Profile / Index.php
index 653eb2a199c900b60fc034fc480aedc40acedfa6..7a009739e4743b3983203a946be2ed7db416a4f6 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * @copyright Copyright (C) 2010-2021, the Friendica project
+ * @copyright Copyright (C) 2010-2023, the Friendica project
  *
  * @license GNU AGPL version 3 or any later version
  *
 
 namespace Friendica\Module\Profile;
 
+use Friendica\App;
 use Friendica\BaseModule;
+use Friendica\Content\Conversation;
+use Friendica\Core\Config\Capability\IManageConfigValues;
 use Friendica\Core\L10n;
+use Friendica\Core\PConfig\Capability\IManagePersonalConfigValues;
+use Friendica\Core\Session\Capability\IHandleUserSessions;
+use Friendica\Database\Database;
+use Friendica\Module\Response;
+use Friendica\Profile\ProfileField\Repository\ProfileField;
+use Friendica\Util\DateTimeFormat;
+use Friendica\Util\Profiler;
+use Psr\Log\LoggerInterface;
 
 /**
  * Profile index router
@@ -31,17 +42,54 @@ use Friendica\Core\L10n;
  * ActivityPub endpoint, but it should show statuses to web users.
  *
  * Both these view have dedicated sub-paths,
- * respectively https://domain.tld/profile/nickname/profile and https://domain.tld/profile/nickname/status
+ * respectively https://domain.tld/profile/nickname/profile and https://domain.tld/profile/nickname/conversations
  */
 class Index extends BaseModule
 {
-       public function rawContent()
+       /** @var Database */
+       private $database;
+       /** @var App */
+       private $app;
+       /** @var IHandleUserSessions */
+       private $session;
+       /** @var IManageConfigValues */
+       private $config;
+       /** @var App\Page */
+       private $page;
+       /** @var ProfileField */
+       private $profileField;
+       /** @var DateTimeFormat */
+       private $dateTimeFormat;
+       /** @var Conversation */
+       private $conversation;
+       /** @var IManagePersonalConfigValues */
+       private $pConfig;
+       /** @var App\Mode */
+       private $mode;
+
+       public function __construct(App\Mode $mode, IManagePersonalConfigValues $pConfig, Conversation $conversation, DateTimeFormat $dateTimeFormat, ProfileField $profileField, App\Page $page, IManageConfigValues $config, IHandleUserSessions $session, App $app, Database $database, L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, array $server, array $parameters = [])
+       {
+               parent::__construct($l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
+
+               $this->database       = $database;
+               $this->app            = $app;
+               $this->session        = $session;
+               $this->config         = $config;
+               $this->page           = $page;
+               $this->profileField   = $profileField;
+               $this->dateTimeFormat = $dateTimeFormat;
+               $this->conversation   = $conversation;
+               $this->pConfig        = $pConfig;
+               $this->mode           = $mode;
+       }
+
+       protected function rawContent(array $request = [])
        {
-               (new Profile($this->l10n, $this->parameters))->rawContent();
+               (new Profile($this->profileField, $this->page, $this->config, $this->session, $this->app, $this->database, $this->l10n, $this->baseUrl, $this->args, $this->logger, $this->profiler, $this->response, $this->server, $this->parameters))->rawContent();
        }
 
-       public function content(): string
+       protected function content(array $request = []): string
        {
-               return (new Status($this->l10n, $this->parameters))->content();
+               return (new Conversations($this->mode, $this->pConfig, $this->conversation, $this->session, $this->config, $this->dateTimeFormat, $this->page, $this->app, $this->l10n, $this->baseUrl, $this->args, $this->logger, $this->profiler, $this->response, $this->server, $this->parameters))->content();
        }
 }