mirror of
https://github.com/friendica/friendica
synced 2024-12-27 01:20:16 +00:00
130 lines
3.5 KiB
PHP
130 lines
3.5 KiB
PHP
<?php
|
|
/**
|
|
* @copyright Copyright (C) 2010-2021, the Friendica project
|
|
*
|
|
* @license GNU AGPL version 3 or any later version
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
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());
|
|
|
|
if (DI::pConfig()->get(local_user(), 'system', 'detailed_notif')) {
|
|
$notify->seen = true;
|
|
DI::notify()->update($notify);
|
|
} else {
|
|
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.');
|
|
}
|
|
}
|