Merge pull request #12630 from annando/diaspora-item

Diaspora: Support for native photos
This commit is contained in:
Hypolite Petovan 2023-01-07 17:19:42 -05:00 committed by GitHub
commit 91bd03a75f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 72 additions and 1 deletions

View file

@ -137,6 +137,18 @@ class Photo extends BaseModule
$scale = intval(substr($photoid, -1, 1)); $scale = intval(substr($photoid, -1, 1));
$photoid = substr($photoid, 0, -2); $photoid = substr($photoid, 0, -2);
} }
if (!empty($this->parameters['size'])) {
switch ($this->parameters['size']) {
case 'thumb_small':
$scale = 2;
break;
case 'scaled_full':
$scale = 1;
break;
}
}
$photo = MPhoto::getPhoto($photoid, $scale); $photo = MPhoto::getPhoto($photoid, $scale);
if ($photo === false) { if ($photo === false) {
throw new HTTPException\NotFoundException(DI::l10n()->t('The Photo with id %s is not available.', $photoid)); throw new HTTPException\NotFoundException(DI::l10n()->t('The Photo with id %s is not available.', $photoid));

View file

@ -1707,6 +1707,7 @@ class Transmitter
$language = self::getLanguage($item); $language = self::getLanguage($item);
if (!empty($language)) { if (!empty($language)) {
$richbody = BBCode::setMentionsToNicknames($item['body'] ?? ''); $richbody = BBCode::setMentionsToNicknames($item['body'] ?? '');
$richbody = Post\Media::removeFromEndOfBody($richbody);
if (!empty($item['quote-uri-id'])) { if (!empty($item['quote-uri-id'])) {
if ($real_quote) { if ($real_quote) {
$richbody = DI::contentItem()->addShareLink($richbody, $item['quote-uri-id']); $richbody = DI::contentItem()->addShareLink($richbody, $item['quote-uri-id']);

View file

@ -3316,8 +3316,16 @@ class Diaspora
$type = 'reshare'; $type = 'reshare';
} else { } else {
$native_photos = DI::config()->get('diaspora', 'native_photos');
if ($native_photos) {
$item['body'] = Post\Media::removeFromEndOfBody($item['body']);
$attach_media = [Post\Media::AUDIO, Post\Media::VIDEO];
} else {
$attach_media = [Post\Media::AUDIO, Post\Media::IMAGE, Post\Media::VIDEO];
}
$title = $item['title']; $title = $item['title'];
$body = Post\Media::addAttachmentsToBody($item['uri-id'], DI::contentItem()->addSharedPost($item)); $body = Post\Media::addAttachmentsToBody($item['uri-id'], DI::contentItem()->addSharedPost($item), $attach_media);
// Fetch the title from an attached link - if there is one // Fetch the title from an attached link - if there is one
if (empty($item['title']) && DI::pConfig()->get($owner['uid'], 'system', 'attach_link_title')) { if (empty($item['title']) && DI::pConfig()->get($owner['uid'], 'system', 'attach_link_title')) {
@ -3365,6 +3373,10 @@ class Diaspora
'location' => $location 'location' => $location
]; ];
if ($native_photos) {
$message = self::addPhotos($item, $message);
}
// Diaspora rejects messages when they contain a location without "lat" or "lng" // Diaspora rejects messages when they contain a location without "lat" or "lng"
if (!isset($location['lat']) || !isset($location['lng'])) { if (!isset($location['lat']) || !isset($location['lng'])) {
unset($message['location']); unset($message['location']);
@ -3399,6 +3411,44 @@ class Diaspora
return $msg; return $msg;
} }
/**
* Add photo elements to the message array
*
* @param array $item
* @param array $message
* @return array
*/
private static function addPhotos(array $item, array $message): array
{
$medias = Post\Media::getByURIId($item['uri-id'], [Post\Media::IMAGE]);
$public = ($item['private'] == Item::PRIVATE ? 'false' : 'true');
$counter = 0;
foreach ($medias as $media) {
if (Item::containsLink($item['body'], $media['preview'] ?? $media['url'], $media['type'])) {
continue;
}
$name = basename($media['url']);
$path = str_replace($name, '', $media['url']);
$message[++$counter . ':photo'] = [
'guid' => Item::guid(['uri' => $media['url']], false),
'author' => $item['author-addr'],
'public' => $public,
'created_at' => $item['created'],
'remote_photo_path' => $path,
'remote_photo_name' => $name,
'status_message_guid' => $item['guid'],
'height' => $media['height'],
'width' => $media['width'],
'text' => $media['description'],
];
}
return $message;
}
private static function prependParentAuthorMention(string $body, string $profile_url): string private static function prependParentAuthorMention(string $body, string $profile_url): string
{ {
$profile = Contact::getByURL($profile_url, false, ['addr', 'name']); $profile = Contact::getByURL($profile_url, false, ['addr', 'name']);

View file

@ -711,6 +711,13 @@ return [
// Must be writable by the ejabberd process. if set then it will prevent the running of multiple processes. // Must be writable by the ejabberd process. if set then it will prevent the running of multiple processes.
'lockpath' => '', 'lockpath' => '',
], ],
'diaspora' => [
// native_photos (Boolean)
// If enabled, photos to Diaspora will be transmitted via the "photo" element instead of embedding them to the body.
// This is some visual improvement over the embedding but comes with the cost of losing accessibility.
// Is is disabled by default until Diaspora eventually will work on issue https://github.com/diaspora/diaspora/issues/8297
'native_photos' => false,
],
'debug' => [ 'debug' => [
// ap_inbox_log (Boolean) // ap_inbox_log (Boolean)
// Logs every call to /inbox as a JSON file in Friendica's temporary directory // Logs every call to /inbox as a JSON file in Friendica's temporary directory

View file

@ -554,6 +554,7 @@ return [
'/permission/tooltip/{type}/{id:\d+}' => [Module\PermissionTooltip::class, [R::GET]], '/permission/tooltip/{type}/{id:\d+}' => [Module\PermissionTooltip::class, [R::GET]],
'/photo' => [ '/photo' => [
'/{size:thumb_small|scaled_full}_{name}' => [Module\Photo::class, [R::GET]],
'/{name}' => [Module\Photo::class, [R::GET]], '/{name}' => [Module\Photo::class, [R::GET]],
'/{type}/{id:\d+}' => [Module\Photo::class, [R::GET]], '/{type}/{id:\d+}' => [Module\Photo::class, [R::GET]],
'/{type:contact|header}/{guid}' => [Module\Photo::class, [R::GET]], '/{type:contact|header}/{guid}' => [Module\Photo::class, [R::GET]],