This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
gnu-social-v2-archive-activ.../classes/Activitypub_notice.php

109 lines
4.1 KiB
PHP
Raw Normal View History

<?php
/**
* GNU social - a federating social network
*
2018-07-09 23:43:34 +01:00
* ActivityPubPlugin implementation for GNU Social
*
* LICENCE: 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 <http://www.gnu.org/licenses/>.
*
* @category Plugin
* @package GNUsocial
* @author Daniel Supernault <danielsupernault@gmail.com>
* @author Diogo Cordeiro <diogo@fc.up.pt>
2018-07-09 23:43:34 +01:00
* @copyright 2018 Free Software Foundation http://fsf.org
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
2018-07-09 23:43:34 +01:00
* @link https://www.gnu.org/software/social/
*/
if (!defined('GNUSOCIAL')) {
exit(1);
2018-07-09 23:43:34 +01:00
}
2018-07-09 23:43:34 +01:00
/**
2018-07-13 12:32:27 +01:00
* ActivityPub notice representation
*
2018-07-09 23:43:34 +01:00
* @category Plugin
* @package GNUsocial
* @author Diogo Cordeiro <diogo@fc.up.pt>
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://www.gnu.org/software/social/
*/
class Activitypub_notice extends Managed_DataObject
{
/**
* Generates a pretty notice from a Notice object
*
* @author Diogo Cordeiro <diogo@fc.up.pt>
* @param Notice $notice
* @return pretty array to be used in a response
*/
public static function notice_to_array($notice)
{
$profile = $notice->getProfile();
2018-07-31 20:09:47 +01:00
$attachments = [];
foreach ($notice->attachments() as $attachment) {
$attachments[] = Activitypub_attachment::attachment_to_array($attachment);
}
2018-07-31 20:09:47 +01:00
$tags = [];
foreach ($notice->getTags() as $tag) {
if ($tag != "") { // Hacky workaround to avoid stupid outputs
$tags[] = Activitypub_tag::tag_to_array($tag);
}
}
2018-05-05 01:14:27 +01:00
$to = [];
foreach ($notice->getAttentionProfiles() as $to_profile) {
2018-07-31 20:09:47 +01:00
$to[] = $href = $to_profile->getUri();
$tags[] = Activitypub_mention_tag::mention_tag_to_array_from_values($href, $to_profile->getNickname().'@'.parse_url($href, PHP_URL_HOST));
}
2018-07-09 23:43:34 +01:00
2018-07-31 20:09:47 +01:00
// In a world without walls and fences, we should make everything Public!
$to[]= 'https://www.w3.org/ns/activitystreams#Public';
$item = [
2018-07-31 20:09:47 +01:00
'@context' => 'https://www.w3.org/ns/activitystreams',
2018-07-29 02:57:46 +01:00
'id' => $notice->getUrl(),
'type' => 'Note',
2018-07-31 20:09:47 +01:00
'published' => str_replace(' ', 'T', $notice->getCreated()).'Z',
2018-07-29 02:57:46 +01:00
'url' => $notice->getUrl(),
'atributedTo' => ActivityPubPlugin::actor_uri($profile),
'to' => $to,
2018-07-31 20:09:47 +01:00
'cc' => common_local_url('apActorFollowers', ['id' => $profile->getID()]),
2018-07-29 02:57:46 +01:00
'atomUri' => $notice->getUrl(),
'conversation' => $notice->getConversationUrl(),
'content' => $notice->getContent(),
2018-07-31 20:09:47 +01:00
'isLocal' => $notice->isLocal(),
2018-07-29 02:57:46 +01:00
'attachment' => $attachments,
'tag' => $tags
];
2018-07-31 20:09:47 +01:00
// Is this a reply?
if (!empty($notice->reply_to)) {
$item['inReplyTo'] = Notice::getById($notice->reply_to)->getUrl();
$item['inReplyToAtomUri'] = Notice::getById($notice->reply_to)->getUrl();
}
2018-07-29 02:57:46 +01:00
// Do we have a location for this notice?
try {
$location = Notice_location::locFromStored($notice);
$item['latitude'] = $location->lat;
$item['longitude'] = $location->lon;
} catch (Exception $ex) {
// Apparently no.
}
2018-07-09 20:07:35 +01:00
return $item;
}
2018-05-05 01:14:27 +01:00
}