namespace Friendica\Module;
use Friendica\BaseModule;
-use Friendica\Core\System;
use Friendica\DI;
use Friendica\Model\User;
use Friendica\Protocol\ActivityPub;
+use Friendica\Util\HTTPSignature;
/**
* ActivityPub Outbox
$page = $_REQUEST['page'] ?? null;
- /// @todo Add Authentication to enable fetching of non public content
- // $requester = HTTPSignature::getSigner('', $_SERVER);
-
- $outbox = ActivityPub\Transmitter::getOutbox($owner, $page);
-
+ $requester = HTTPSignature::getSigner('', $_SERVER);
+ $outbox = ActivityPub\Transmitter::getOutbox($owner, $page, $requester);
header('Content-Type: application/activity+json');
echo json_encode($outbox);
exit();
/**
* Public posts for the given owner
*
- * @param array $owner Owner array
- * @param integer $page Page numbe
+ * @param array $owner Owner array
+ * @param integer $page Page number
+ * @param string $requester URL of requesting account
*
* @return array of posts
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
* @throws \ImagickException
*/
- public static function getOutbox($owner, $page = null)
+ public static function getOutbox($owner, $page = null, $requester = '')
{
$public_contact = Contact::getIdForURL($owner['url']);
+ $condition = ['uid' => 0, 'contact-id' => $public_contact,
+ 'private' => [Item::PUBLIC, Item::UNLISTED]];
+
+ if (!empty($requester)) {
+ $requester_id = Contact::getIdForURL($requester, $owner['uid']);
+ if (!empty($requester_id)) {
+ $permissionSets = DI::permissionSet()->selectByContactId($requester_id, $owner['uid']);
+ if (!empty($permissionSets)) {
+ $condition = ['uid' => $owner['uid'], 'origin' => true,
+ 'psid' => array_merge($permissionSets->column('id'),
+ [DI::permissionSet()->getIdFromACL($owner['uid'], '', '', '', '')])];
+ }
+ }
+ }
+
+ $condition = array_merge($condition,
+ ['author-id' => $public_contact,
+ 'gravity' => [GRAVITY_PARENT, GRAVITY_COMMENT],
+ 'deleted' => false, 'visible' => true, 'moderated' => false]);
- $condition = ['uid' => 0, 'contact-id' => $public_contact, 'author-id' => $public_contact,
- 'private' => [Item::PUBLIC, Item::UNLISTED], 'gravity' => [GRAVITY_PARENT, GRAVITY_COMMENT],
- 'deleted' => false, 'visible' => true, 'moderated' => false];
$count = DBA::count('item', $condition);
$data = ['@context' => ActivityPub::CONTEXT];