Merge pull request 'Tumblr: Transmit multiple photos' (#1361) from heluecht/friendica-addons:tumblr-photos into develop

Reviewed-on: friendica/friendica-addons#1361
This commit is contained in:
Hypolite Petovan 2023-03-09 22:02:22 +01:00
commit efdc4fa3c0

View file

@ -15,8 +15,10 @@ use Friendica\Core\Logger;
use Friendica\Core\Renderer; use Friendica\Core\Renderer;
use Friendica\DI; use Friendica\DI;
use Friendica\Model\Item; use Friendica\Model\Item;
use Friendica\Model\Photo;
use Friendica\Model\Post; use Friendica\Model\Post;
use Friendica\Model\Tag; use Friendica\Model\Tag;
use Friendica\Util\Network;
function tumblr_install() function tumblr_install()
{ {
@ -308,7 +310,6 @@ function tumblr_post_local(array &$b)
function tumblr_send(array &$b) function tumblr_send(array &$b)
{ {
if ($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited'])) { if ($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited'])) {
return; return;
} }
@ -321,7 +322,7 @@ function tumblr_send(array &$b)
return; return;
} }
$b['body'] = Post\Media::addAttachmentsToBody($b['uri-id'], DI::contentItem()->addSharedPost($b)); $b['body'] = BBCode::removeAttachment($b['body']);
$oauth_token = DI::pConfig()->get($b['uid'], 'tumblr', 'oauth_token'); $oauth_token = DI::pConfig()->get($b['uid'], 'tumblr', 'oauth_token');
$oauth_token_secret = DI::pConfig()->get($b['uid'], 'tumblr', 'oauth_token_secret'); $oauth_token_secret = DI::pConfig()->get($b['uid'], 'tumblr', 'oauth_token_secret');
@ -358,16 +359,23 @@ function tumblr_send(array &$b)
]; ];
$body = BBCode::removeShareInformation($b['body']); $body = BBCode::removeShareInformation($b['body']);
$body = Post\Media::removeFromEndOfBody($body);
if ($photo != false) { if ($photo !== false) {
$params['type'] = 'photo'; $params['type'] = 'photo';
if (!empty($body)) {
$params['caption'] = BBCode::convertForUriId($b['uri-id'], $body, BBCode::CONNECTORS); $params['caption'] = BBCode::convertForUriId($b['uri-id'], $body, BBCode::CONNECTORS);
} elseif (!empty($params['caption'])) { $params['data'] = [];
$params['caption'] = $media[$photo]['description']; foreach ($media as $photo) {
if ($photo['type'] == Post\Media::IMAGE) {
if (Network::isLocalLink($photo['url']) && ($data = Photo::getResourceData($photo['url']))) {
$photo = Photo::selectFirst([], ["`resource-id` = ? AND `scale` > ?", $data['guid'], 0]);
if (!empty($photo)) {
$params['data'][] = Photo::getImageDataForPhoto($photo);
} }
$params['source'] = $media[$photo]['url']; }
} elseif ($link != false) { }
}
} elseif ($link !== false) {
$params['type'] = 'link'; $params['type'] = 'link';
$params['title'] = $media[$link]['name']; $params['title'] = $media[$link]['name'];
$params['url'] = $media[$link]['url']; $params['url'] = $media[$link]['url'];
@ -381,14 +389,12 @@ function tumblr_send(array &$b)
} }
if (!empty($media[$link]['author-name'])) { if (!empty($media[$link]['author-name'])) {
$params['author'] = $media[$link]['author-name']; $params['author'] = $media[$link]['author-name'];
} elseif (!empty($media[$link]['publisher-name'])) {
$params['author'] = $media[$link]['publisher-name'];
} }
} elseif ($audio != false) { } elseif ($audio !== false) {
$params['type'] = 'audio'; $params['type'] = 'audio';
$params['external_url'] = $media[$audio]['url']; $params['external_url'] = $media[$audio]['url'];
$params['caption'] = BBCode::convertForUriId($b['uri-id'], $body, BBCode::CONNECTORS); $params['caption'] = BBCode::convertForUriId($b['uri-id'], $body, BBCode::CONNECTORS);
} elseif ($video != false) { } elseif ($video !== false) {
$params['type'] = 'video'; $params['type'] = 'video';
$params['embed'] = $media[$video]['url']; $params['embed'] = $media[$video]['url'];
$params['caption'] = BBCode::convertForUriId($b['uri-id'], $body, BBCode::CONNECTORS); $params['caption'] = BBCode::convertForUriId($b['uri-id'], $body, BBCode::CONNECTORS);
@ -413,11 +419,11 @@ function tumblr_send(array &$b)
$ret_code = $tum_oauth->http_code; $ret_code = $tum_oauth->http_code;
if ($ret_code == 201) { if ($ret_code == 201) {
Logger::notice('tumblr_send: success'); Logger::info('success', ['blog' => $tmbl_blog, 'params' => $params]);
} elseif ($ret_code == 403) { } elseif ($ret_code == 403) {
Logger::notice('tumblr_send: authentication failure'); Logger::notice('authentication failure', ['blog' => $tmbl_blog, 'params' => $params]);
} else { } else {
Logger::notice('tumblr_send: general error', ['error' => $x]); Logger::notice('general error', ['blog' => $tmbl_blog, 'params' => $params, 'error' => $x]);
} }
} }
} }