. * */ namespace Friendica\Module\Notifications; use Friendica\BaseModule; use Friendica\Core\System; use Friendica\DI; use Friendica\Module\Security\Login; use Friendica\Network\HTTPException; /** * Interacting with the /notification command */ class Notification extends BaseModule { /** * {@inheritDoc} * * @throws HTTPException\InternalServerErrorException * @throws HTTPException\NotFoundException * @throws HTTPException\UnauthorizedException * @throws \ImagickException * @throws \Exception */ public static function post(array $parameters = []) { if (!local_user()) { throw new HTTPException\UnauthorizedException(DI::l10n()->t('Permission denied.')); } $request_id = $parameters['id'] ?? false; if ($request_id) { $intro = DI::intro()->selectFirst(['id' => $request_id, 'uid' => local_user()]); switch ($_POST['submit']) { case DI::l10n()->t('Discard'): $intro->discard(); break; case DI::l10n()->t('Ignore'): $intro->ignore(); break; } DI::baseUrl()->redirect('notifications/intros'); } } /** * {@inheritDoc} * * @throws HTTPException\UnauthorizedException */ public static function rawContent(array $parameters = []) { if (!local_user()) { throw new HTTPException\UnauthorizedException(DI::l10n()->t('Permission denied.')); } if (DI::args()->get(1) === 'mark' && DI::args()->get(2) === 'all') { try { $success = DI::notify()->setSeen(); } catch (\Exception $e) { DI::logger()->warning('set all seen failed.', ['exception' => $e]); $success = false; } System::jsonExit(['result' => (($success) ? 'success' : 'fail')]); } } /** * {@inheritDoc} * * Redirect to the notifications main page or to the url for the chosen notifications * * @throws HTTPException\NotFoundException In case the notification is either not existing or is not for this user * @throws HTTPException\InternalServerErrorException * @throws \Exception */ public static function content(array $parameters = []) { if (!local_user()) { notice(DI::l10n()->t('You must be logged in to show this page.')); return Login::form(); } $request_id = $parameters['id'] ?? false; if ($request_id) { $notify = DI::notify()->getByID($request_id, local_user()); DI::notify()->setSeen(true, $notify); if (!empty($notify->link)) { System::externalRedirect($notify->link); } DI::baseUrl()->redirect(); } DI::baseUrl()->redirect('notifications/system'); throw new HTTPException\InternalServerErrorException('Invalid situation.'); } }