2018-09-10 17:07:25 -04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @file src/Module/Inbox.php
|
|
|
|
*/
|
2019-01-22 12:19:15 -05:00
|
|
|
|
2018-09-10 17:07:25 -04:00
|
|
|
namespace Friendica\Module;
|
|
|
|
|
|
|
|
use Friendica\BaseModule;
|
2019-01-23 21:22:39 -05:00
|
|
|
use Friendica\Core\Logger;
|
2018-09-15 06:14:56 -04:00
|
|
|
use Friendica\Database\DBA;
|
2019-12-15 16:34:11 -05:00
|
|
|
use Friendica\DI;
|
2019-05-01 15:29:04 -04:00
|
|
|
use Friendica\Protocol\ActivityPub;
|
2019-01-22 12:15:42 -05:00
|
|
|
use Friendica\Util\HTTPSignature;
|
2019-07-30 18:26:01 -04:00
|
|
|
use Friendica\Util\Network;
|
2018-09-10 17:07:25 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* ActivityPub Inbox
|
|
|
|
*/
|
|
|
|
class Inbox extends BaseModule
|
|
|
|
{
|
2019-11-05 16:48:54 -05:00
|
|
|
public static function rawContent(array $parameters = [])
|
2018-09-10 17:07:25 -04:00
|
|
|
{
|
2019-12-15 16:34:11 -05:00
|
|
|
$a = DI::app();
|
2018-09-10 17:07:25 -04:00
|
|
|
|
2019-07-30 18:26:01 -04:00
|
|
|
$postdata = Network::postdata();
|
2018-09-10 17:07:25 -04:00
|
|
|
|
2018-09-12 02:01:28 -04:00
|
|
|
if (empty($postdata)) {
|
2019-05-01 23:16:10 -04:00
|
|
|
throw new \Friendica\Network\HTTPException\BadRequestException();
|
2018-09-10 17:07:25 -04:00
|
|
|
}
|
|
|
|
|
2020-01-19 15:21:13 -05:00
|
|
|
if (DI::config()->get('debug', 'ap_inbox_log')) {
|
2019-01-22 12:19:15 -05: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 12:15:42 -05:00
|
|
|
|
2019-05-01 15:29:04 -04:00
|
|
|
// @TODO: Replace with parameter from router
|
2018-09-15 06:14:56 -04:00
|
|
|
if (!empty($a->argv[1])) {
|
|
|
|
$user = DBA::selectFirst('user', ['uid'], ['nickname' => $a->argv[1]]);
|
|
|
|
if (!DBA::isResult($user)) {
|
2019-05-01 23:16:10 -04:00
|
|
|
throw new \Friendica\Network\HTTPException\NotFoundException();
|
2018-09-15 06:14:56 -04:00
|
|
|
}
|
|
|
|
$uid = $user['uid'];
|
|
|
|
} else {
|
|
|
|
$uid = 0;
|
|
|
|
}
|
|
|
|
|
2018-10-03 05:15:38 -04:00
|
|
|
ActivityPub\Receiver::processInbox($postdata, $_SERVER, $uid);
|
2018-09-14 12:51:32 -04:00
|
|
|
|
2019-05-01 23:16:10 -04:00
|
|
|
throw new \Friendica\Network\HTTPException\AcceptedException();
|
2018-09-10 17:07:25 -04:00
|
|
|
}
|
|
|
|
}
|