From 35cc3588080279c0fea116100a5f1016c8b6212c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Julius=20H=C3=A4rtl?= Date: Tue, 23 Oct 2018 15:37:18 +0200 Subject: [PATCH] Add basic endpoint for account data MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Julius Härtl --- appinfo/routes.php | 6 ++ lib/Controller/NavigationController.php | 84 +++++++++++++++++++++++-- templates/actor.php | 1 - templates/followers.php | 1 - templates/following.php | 1 - templates/main.php | 1 + 6 files changed, 87 insertions(+), 7 deletions(-) delete mode 100644 templates/actor.php delete mode 100644 templates/followers.php delete mode 100644 templates/following.php diff --git a/appinfo/routes.php b/appinfo/routes.php index e1ba5193..5b894353 100644 --- a/appinfo/routes.php +++ b/appinfo/routes.php @@ -10,8 +10,14 @@ return [ 'routes' => [ ['name' => 'Navigation#navigate', 'url' => '/', 'verb' => 'GET'], + ['name' => 'Navigation#timeline', 'url' => '/timeline/{path}', 'verb' => 'GET', 'requirements' => ['path' => '.+'], 'defaults' => ['path' => '']], + ['name' => 'Navigation#account', 'url' => '/account/{path}', 'verb' => 'GET', 'requirements' => ['path' => '.+'], 'defaults' => ['path' => '']], + ['name' => 'Navigation#public', 'url' => '/{username}', 'verb' => 'GET'], + // ['name' => 'Account#create', 'url' => '/local/account/{username}', 'verb' => 'POST'], + ['name' => 'Account#info', 'url' => '/local/account/{username}', 'verb' => 'GET'], + ['name' => 'ActivityPub#sharedInbox', 'url' => '/inbox', 'verb' => 'POST'], ['name' => 'ActivityPub#actor', 'url' => '/users/{username}', 'verb' => 'GET'], diff --git a/lib/Controller/NavigationController.php b/lib/Controller/NavigationController.php index bf584ab7..6437702e 100644 --- a/lib/Controller/NavigationController.php +++ b/lib/Controller/NavigationController.php @@ -30,14 +30,18 @@ declare(strict_types=1); namespace OCA\Social\Controller; +use OC\Accounts\AccountManager; use OC\User\NoUserException; use OCA\Social\AppInfo\Application; use OCA\Social\Exceptions\AccountAlreadyExistsException; use OCA\Social\Service\ActorService; use OCA\Social\Service\MiscService; use OCP\AppFramework\Controller; +use OCP\AppFramework\Http\RedirectResponse; +use OCP\AppFramework\Http\Template\PublicTemplateResponse; use OCP\AppFramework\Http\TemplateResponse; use OCP\IConfig; +use OCP\IL10N; use OCP\IRequest; use OCP\IURLGenerator; @@ -58,6 +62,8 @@ class NavigationController extends Controller { /** @var MiscService */ private $miscService; + /** @var IL10N */ + private $l10n; /** * NavigationController constructor. @@ -70,8 +76,8 @@ class NavigationController extends Controller { * @param MiscService $miscService */ public function __construct( - IRequest $request, string $userId, IConfig $config, IURLGenerator $urlGenerator, - ActorService $actorService, MiscService $miscService + IRequest $request, $userId, IConfig $config, IURLGenerator $urlGenerator, + ActorService $actorService, MiscService $miscService, IL10N $l10n ) { parent::__construct(Application::APP_NAME, $request); @@ -81,6 +87,7 @@ class NavigationController extends Controller { $this->actorService = $actorService; $this->miscService = $miscService; + $this->l10n = $l10n; } @@ -94,8 +101,12 @@ class NavigationController extends Controller { * @return TemplateResponse * @throws NoUserException */ - public function navigate(): TemplateResponse { - $data = []; + public function navigate($path = ''): TemplateResponse { + $data = [ + 'serverData' => [ + 'public' => false, + ] + ]; try { $this->actorService->createActor($this->userId, $this->userId); @@ -103,8 +114,73 @@ class NavigationController extends Controller { // we do nothing } + + return new TemplateResponse(Application::APP_NAME, 'main', $data); } + /** + * Display the navigation page of the Social app. + * + * @NoCSRFRequired + * @NoAdminRequired + * @NoSubAdminRequired + * + * @return TemplateResponse + * @throws NoUserException + */ + public function timeline($path = ''): TemplateResponse { + return $this->navigate(); + } + + /** + * Display the navigation page of the Social app. + * + * @NoCSRFRequired + * @NoAdminRequired + * @NoSubAdminRequired + * + * @return TemplateResponse + * @throws NoUserException + */ + public function account($path = ''): TemplateResponse { + return $this->navigate(); + } + + /** + * @NoCSRFRequired + * @PublicPage + * + * @param $username + * @return RedirectResponse|PublicTemplateResponse + */ + public function public($username) { + if (\OC::$server->getUserSession()->isLoggedIn()) { + return new RedirectResponse(\OC::$server->getURLGenerator()->linkToRoute('social.Navigation.navigate')); + } + // TODO public interface for account manager + /** @var AccountManager $accountManager */ + $accountManager = \OC::$server->query(AccountManager::class); + $userData = $accountManager->getUser(\OC::$server->getUserManager()->get($username)); + + $data = [ + 'username' => $username, + 'displayName' => $this->getPublicValue($userData, AccountManager::PROPERTY_DISPLAYNAME), + 'website' => $this->getPublicValue($userData, AccountManager::PROPERTY_WEBSITE), + 'account' => json_encode($userData), + 'serverData' => [ + 'public' => true, + ] + ]; + $page = new PublicTemplateResponse(Application::APP_NAME, 'main', $data); + $page->setHeaderTitle($this->l10n->t('Social') . ' ' . $username); + return $page; + } + + private function getPublicValue($userData, $value) { + if ($userData[$value]['scope'] === 'public') { + return $userData[$value]['value']; + } + } } diff --git a/templates/actor.php b/templates/actor.php deleted file mode 100644 index cab3b5fc..00000000 --- a/templates/actor.php +++ /dev/null @@ -1 +0,0 @@ -ACTOR ! diff --git a/templates/followers.php b/templates/followers.php deleted file mode 100644 index 82235440..00000000 --- a/templates/followers.php +++ /dev/null @@ -1 +0,0 @@ -FOLLOWERS !!!1 diff --git a/templates/following.php b/templates/following.php deleted file mode 100644 index c040e4d9..00000000 --- a/templates/following.php +++ /dev/null @@ -1 +0,0 @@ -FOLLOWING diff --git a/templates/main.php b/templates/main.php index 82e60c1f..34ea59d6 100644 --- a/templates/main.php +++ b/templates/main.php @@ -2,4 +2,5 @@ script('social', 'social'); style('social', 'style'); ?> +