mirror of
https://github.com/friendica/friendica
synced 2025-04-03 16:40:14 +00:00
99 lines
3.1 KiB
PHP
99 lines
3.1 KiB
PHP
<?php
|
|
|
|
// Copyright (C) 2010-2024, the Friendica project
|
|
// SPDX-FileCopyrightText: 2010-2024 the Friendica project
|
|
//
|
|
// SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
namespace Friendica\Module\ActivityPub;
|
|
|
|
use Friendica\Core\Logger;
|
|
use Friendica\Core\Protocol;
|
|
use Friendica\Core\System;
|
|
use Friendica\Database\DBA;
|
|
use Friendica\DI;
|
|
use Friendica\Model\Item;
|
|
use Friendica\Model\User;
|
|
use Friendica\Module\BaseApi;
|
|
use Friendica\Module\Special\HTTPException;
|
|
use Friendica\Protocol\ActivityPub;
|
|
use Friendica\Util\HTTPSignature;
|
|
use Friendica\Util\Network;
|
|
use Psr\Http\Message\ResponseInterface;
|
|
|
|
/**
|
|
* ActivityPub Inbox
|
|
*/
|
|
class Inbox extends BaseApi
|
|
{
|
|
public function run(HTTPException $httpException, array $request = [], bool $scopecheck = true): ResponseInterface
|
|
{
|
|
return parent::run($httpException, $request, false);
|
|
}
|
|
|
|
protected function rawContent(array $request = [])
|
|
{
|
|
$this->checkAllowedScope(self::SCOPE_READ);
|
|
$uid = self::getCurrentUserID();
|
|
$page = $request['page'] ?? null;
|
|
|
|
if (empty($page) && empty($request['max_id'])) {
|
|
$page = 1;
|
|
}
|
|
|
|
if (!empty($this->parameters['nickname'])) {
|
|
$owner = User::getOwnerDataByNick($this->parameters['nickname']);
|
|
if (empty($owner)) {
|
|
throw new \Friendica\Network\HTTPException\NotFoundException();
|
|
}
|
|
if ($owner['uid'] != $uid) {
|
|
throw new \Friendica\Network\HTTPException\ForbiddenException();
|
|
}
|
|
$inbox = ActivityPub\ClientToServer::getInbox($uid, $page, $request['max_id'] ?? null);
|
|
} else {
|
|
$inbox = ActivityPub\ClientToServer::getPublicInbox($uid, $page, $request['max_id'] ?? null);
|
|
}
|
|
|
|
$this->jsonExit($inbox, 'application/activity+json');
|
|
}
|
|
|
|
protected function post(array $request = [])
|
|
{
|
|
$postdata = Network::postdata();
|
|
|
|
if (empty($postdata)) {
|
|
throw new \Friendica\Network\HTTPException\BadRequestException();
|
|
}
|
|
|
|
if (!HTTPSignature::isValidContentType($this->server['CONTENT_TYPE'] ?? '')) {
|
|
Logger::notice('Unexpected content type', ['content-type' => $this->server['CONTENT_TYPE'] ?? '', 'agent' => $this->server['HTTP_USER_AGENT'] ?? '']);
|
|
throw new \Friendica\Network\HTTPException\UnsupportedMediaTypeException();
|
|
}
|
|
|
|
if (DI::config()->get('debug', 'ap_inbox_log')) {
|
|
if (HTTPSignature::getSigner($postdata, $_SERVER)) {
|
|
$filename = 'signed-activitypub';
|
|
} else {
|
|
$filename = 'failed-activitypub';
|
|
}
|
|
$tempfile = tempnam(System::getTempPath(), $filename);
|
|
file_put_contents($tempfile, json_encode(['parameters' => $this->parameters, 'header' => $_SERVER, 'body' => $postdata], JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT));
|
|
Logger::notice('Incoming message stored', ['file' => $tempfile]);
|
|
}
|
|
|
|
if (!empty($this->parameters['nickname'])) {
|
|
$user = DBA::selectFirst('user', ['uid'], ['nickname' => $this->parameters['nickname']]);
|
|
if (!DBA::isResult($user)) {
|
|
throw new \Friendica\Network\HTTPException\NotFoundException();
|
|
}
|
|
$uid = $user['uid'];
|
|
} else {
|
|
$uid = 0;
|
|
}
|
|
|
|
Item::incrementInbound(Protocol::ACTIVITYPUB);
|
|
ActivityPub\Receiver::processInbox($postdata, $_SERVER, $uid);
|
|
|
|
throw new \Friendica\Network\HTTPException\AcceptedException();
|
|
}
|
|
}
|