1
0
Fork 0
friendica_2020-09-1_sharedH.../src/Module/Inbox.php

58 lines
1.4 KiB
PHP
Raw Normal View History

<?php
/**
* @file src/Module/Inbox.php
*/
2019-01-22 18:19:15 +01:00
namespace Friendica\Module;
use Friendica\BaseModule;
use Friendica\Core\Logger;
2018-09-15 12:14:56 +02:00
use Friendica\Database\DBA;
use Friendica\DI;
2019-05-01 21:29:04 +02:00
use Friendica\Protocol\ActivityPub;
2019-01-22 18:15:42 +01:00
use Friendica\Util\HTTPSignature;
use Friendica\Util\Network;
/**
* ActivityPub Inbox
*/
class Inbox extends BaseModule
{
public static function rawContent(array $parameters = [])
{
$a = DI::app();
$postdata = Network::postdata();
2018-09-12 08:01:28 +02:00
if (empty($postdata)) {
throw new \Friendica\Network\HTTPException\BadRequestException();
}
if (DI::config()->get('debug', 'ap_inbox_log')) {
2019-01-22 18:19:15 +01:00
if (HTTPSignature::getSigner($postdata, $_SERVER)) {
$filename = 'signed-activitypub';
} else {
$filename = 'failed-activitypub';
}
$tempfile = tempnam(get_temppath(), $filename);
file_put_contents($tempfile, json_encode(['argv' => $a->argv, 'header' => $_SERVER, 'body' => $postdata], JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE));
Logger::log('Incoming message stored under ' . $tempfile);
}
2019-01-22 18:15:42 +01:00
2019-05-01 21:29:04 +02:00
// @TODO: Replace with parameter from router
2018-09-15 12:14:56 +02:00
if (!empty($a->argv[1])) {
$user = DBA::selectFirst('user', ['uid'], ['nickname' => $a->argv[1]]);
if (!DBA::isResult($user)) {
throw new \Friendica\Network\HTTPException\NotFoundException();
2018-09-15 12:14:56 +02:00
}
$uid = $user['uid'];
} else {
$uid = 0;
}
2018-10-03 11:15:38 +02:00
ActivityPub\Receiver::processInbox($postdata, $_SERVER, $uid);
throw new \Friendica\Network\HTTPException\AcceptedException();
}
}