X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModule%2FRemoteFollow.php;h=130c76319c12b43c073d3fd7bcd9971a0f5e6825;hb=e7384288766f342da98b7d0ada082db516501ac6;hp=2a4d6bc1ed36173b0c24c3f116fd58fefed92fd8;hpb=2eebeeaa329584244e414eaa41fc6ac9ed3e1cac;p=friendica.git diff --git a/src/Module/RemoteFollow.php b/src/Module/RemoteFollow.php index 2a4d6bc1ed..130c76319c 100644 --- a/src/Module/RemoteFollow.php +++ b/src/Module/RemoteFollow.php @@ -1,105 +1,135 @@ . + * + */ namespace Friendica\Module; +use Friendica\App; +use Friendica\App\Page; use Friendica\BaseModule; -use Friendica\DI; +use Friendica\Content\Widget; +use Friendica\Core\L10n; use Friendica\Core\Logger; use Friendica\Core\Protocol; use Friendica\Core\Renderer; use Friendica\Core\Search; use Friendica\Core\System; +use Friendica\Model\Contact; use Friendica\Model\Profile; +use Friendica\Model\User; +use Friendica\Network\HTTPException; use Friendica\Network\Probe; +use Friendica\Util\Profiler; +use Psr\Log\LoggerInterface; /** * Remotely follow the account on this system by the provided account */ class RemoteFollow extends BaseModule { - public static function init(array $parameters = []) + /** @var array */ + protected $owner; + /** @var Page */ + protected $page; + + public function __construct(L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, App\Page $page, LoggerInterface $logger, Profiler $profiler, Response $response, array $server, array $parameters = []) { - if (empty($parameters['profile'])) { - return; + parent::__construct($l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters); + + $this->owner = User::getOwnerDataByNick($this->parameters['profile']); + if (!$this->owner) { + throw new HTTPException\NotFoundException($this->t('User not found.')); } - Profile::load(DI::app(), $parameters['profile']); + $this->page = $page; } - public static function post(array $parameters = []) + protected function post(array $request = []) { - $a = DI::app(); - - if (empty($parameters['profile']) || !empty($_POST['cancel']) || empty($_POST['dfrn_url'])) { - DI::baseUrl()->redirect(); + if (!empty($_POST['cancel']) || empty($_POST['dfrn_url'])) { + $this->baseUrl->redirect(); } - if (empty($a->profile['uid'])) { - notice(DI::l10n()->t('Profile unavailable.') . EOL); + if (empty($this->owner)) { + notice($this->t('Profile unavailable.')); return; } - $url = trim($_POST['dfrn_url']); + $url = Probe::cleanURI($_POST['dfrn_url']); if (!strlen($url)) { - notice(DI::l10n()->t("Invalid locator") . EOL); + notice($this->t("Invalid locator")); return; } // Detect the network, make sure the provided URL is valid - $data = Probe::uri($url); - if ($data['network'] == Protocol::PHANTOM) { - notice(DI::l10n()->t("The provided profile link doesn't seem to be valid")); + $data = Contact::getByURL($url); + if (!$data) { + notice($this->t("The provided profile link doesn't seem to be valid")); return; } - // Fetch link for the "remote follow" functionality of the given profile - $follow_link_template = Probe::getRemoteFollowLink($url); - - if (empty($follow_link_template)) { - notice(DI::l10n()->t("Remote subscription can't be done for your network. Please subscribe directly on your system.")); + if (empty($data['subscribe'])) { + notice($this->t("Remote subscription can't be done for your network. Please subscribe directly on your system.")); return; } - Logger::notice('Remote request', ['url' => $url, 'follow' => $a->profile['url'], 'remote' => $follow_link_template]); + Logger::notice('Remote request', ['url' => $url, 'follow' => $this->owner['url'], 'remote' => $data['subscribe']]); - // Substitute our user's feed URL into $follow_link_template + // Substitute our user's feed URL into $data['subscribe'] // Send the subscriber home to subscribe // Diaspora needs the uri in the format user@domain.tld if ($data['network'] == Protocol::DIASPORA) { - $uri = urlencode($a->profile['addr']); + $uri = urlencode($this->owner['addr']); } else { - $uri = urlencode($a->profile['url']); + $uri = urlencode($this->owner['url']); } - $follow_link = str_replace('{uri}', $uri, $follow_link_template); + $follow_link = str_replace('{uri}', $uri, $data['subscribe']); System::externalRedirect($follow_link); } - public static function content(array $parameters = []) + protected function content(array $request = []): string { - $a = DI::app(); - - if (empty($parameters['profile']) || empty($a->profile)) { + if (empty($this->owner)) { return ''; } - - $target_addr = $a->profile['addr']; - $target_url = $a->profile['url']; + + $this->page['aside'] = Widget\VCard::getHTML($this->owner); + + $target_addr = $this->owner['addr']; + $target_url = $this->owner['url']; $tpl = Renderer::getMarkupTemplate('auto_request.tpl'); $o = Renderer::replaceMacros($tpl, [ - '$header' => DI::l10n()->t('Friend/Connection Request'), - '$page_desc' => DI::l10n()->t('Enter your Webfinger address (user@domain.tld) or profile URL here. If this isn\'t supported by your system, you have to subscribe to %s or %s directly on your system.', $target_addr, $target_url), - '$invite_desc' => DI::l10n()->t('If you are not yet a member of the free social web, follow this link to find a public Friendica node and join us today.', Search::getGlobalDirectory() . '/servers'), - '$your_address' => DI::l10n()->t('Your Webfinger address or profile URL:'), - '$pls_answer' => DI::l10n()->t('Please answer the following:'), - '$submit' => DI::l10n()->t('Submit Request'), - '$cancel' => DI::l10n()->t('Cancel'), + '$header' => $this->t('Friend/Connection Request'), + '$page_desc' => $this->t('Enter your Webfinger address (user@domain.tld) or profile URL here. If this isn\'t supported by your system, you have to subscribe to %s or %s directly on your system.', $target_addr, $target_url), + '$invite_desc' => $this->t('If you are not yet a member of the free social web, follow this link to find a public Friendica node and join us today.', Search::getGlobalDirectory() . '/servers'), + '$your_address' => $this->t('Your Webfinger address or profile URL:'), + '$pls_answer' => $this->t('Please answer the following:'), + '$submit' => $this->t('Submit Request'), + '$cancel' => $this->t('Cancel'), - '$request' => 'remote_follow/' . $parameters['profile'], - '$name' => $a->profile['name'], - '$myaddr' => '', //Profile::getMyURL(), + '$request' => 'remote_follow/' . $this->parameters['profile'], + '$name' => $this->owner['name'], + '$myaddr' => Profile::getMyURL(), ]); return $o; } -} \ No newline at end of file +}