mirror of
https://github.com/friendica/friendica
synced 2025-01-10 08:04:43 +00:00
Use the fetched mimetype if present
This commit is contained in:
parent
e177ad55c1
commit
503e33a683
2 changed files with 46 additions and 19 deletions
|
@ -157,8 +157,11 @@ class Media
|
||||||
public static function getAttachElement(string $href, int $length, string $type, string $title = ''): string
|
public static function getAttachElement(string $href, int $length, string $type, string $title = ''): string
|
||||||
{
|
{
|
||||||
$media = self::fetchAdditionalData([
|
$media = self::fetchAdditionalData([
|
||||||
'type' => self::DOCUMENT, 'url' => $href,
|
'type' => self::DOCUMENT,
|
||||||
'size' => $length, 'mimetype' => $type, 'description' => $title
|
'url' => $href,
|
||||||
|
'size' => $length,
|
||||||
|
'mimetype' => $type,
|
||||||
|
'description' => $title
|
||||||
]);
|
]);
|
||||||
|
|
||||||
return '[attach]href="' . $media['url'] . '" length="' . $media['size'] .
|
return '[attach]href="' . $media['url'] . '" length="' . $media['size'] .
|
||||||
|
@ -184,7 +187,7 @@ class Media
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch the mimetype or size if missing.
|
// Fetch the mimetype or size if missing.
|
||||||
if (Network::isValidHttpUrl($media['url']) && empty($media['mimetype']) && !in_array($media['type'], [self::IMAGE, self::HLS])) {
|
if (Network::isValidHttpUrl($media['url']) && (empty($media['mimetype']) || $media['type'] == self::HTML) && !in_array($media['type'], [self::IMAGE, self::HLS])) {
|
||||||
$timeout = DI::config()->get('system', 'xrd_timeout');
|
$timeout = DI::config()->get('system', 'xrd_timeout');
|
||||||
try {
|
try {
|
||||||
$curlResult = DI::httpClient()->head($media['url'], [HttpClientOptions::ACCEPT_CONTENT => HttpClientAccept::AS_DEFAULT, HttpClientOptions::TIMEOUT => $timeout, HttpClientOptions::REQUEST => HttpClientRequest::CONTENTTYPE]);
|
$curlResult = DI::httpClient()->head($media['url'], [HttpClientOptions::ACCEPT_CONTENT => HttpClientAccept::AS_DEFAULT, HttpClientOptions::TIMEOUT => $timeout, HttpClientOptions::REQUEST => HttpClientRequest::CONTENTTYPE]);
|
||||||
|
@ -194,8 +197,8 @@ class Media
|
||||||
$curlResult = DI::httpClient()->get($media['url'], HttpClientAccept::AS_DEFAULT, [HttpClientOptions::TIMEOUT => $timeout]);
|
$curlResult = DI::httpClient()->get($media['url'], HttpClientAccept::AS_DEFAULT, [HttpClientOptions::TIMEOUT => $timeout]);
|
||||||
}
|
}
|
||||||
if ($curlResult->isSuccess()) {
|
if ($curlResult->isSuccess()) {
|
||||||
if (empty($media['mimetype'])) {
|
if (!empty($curlResult->getContentType())) {
|
||||||
$media['mimetype'] = $curlResult->getContentType() ?? '';
|
$media['mimetype'] = $curlResult->getContentType();
|
||||||
}
|
}
|
||||||
if (empty($media['size'])) {
|
if (empty($media['size'])) {
|
||||||
$media['size'] = (int)($curlResult->getHeader('Content-Length')[0] ?? strlen($curlResult->getBodyString() ?? ''));
|
$media['size'] = (int)($curlResult->getHeader('Content-Length')[0] ?? strlen($curlResult->getBodyString() ?? ''));
|
||||||
|
@ -612,20 +615,29 @@ class Media
|
||||||
$body = str_replace($picture[0], '', $body);
|
$body = str_replace($picture[0], '', $body);
|
||||||
$image = str_replace(['-1.', '-2.'], '-0.', $picture[2]);
|
$image = str_replace(['-1.', '-2.'], '-0.', $picture[2]);
|
||||||
$attachments[$image] = [
|
$attachments[$image] = [
|
||||||
'uri-id' => $uriid, 'type' => self::IMAGE, 'url' => $image,
|
'uri-id' => $uriid,
|
||||||
'preview' => $picture[2], 'description' => $picture[3]
|
'type' => self::IMAGE,
|
||||||
|
'url' => $image,
|
||||||
|
'preview' => $picture[2],
|
||||||
|
'description' => $picture[3]
|
||||||
];
|
];
|
||||||
} elseif (self::isLinkToPhoto($picture[1], $picture[2])) {
|
} elseif (self::isLinkToPhoto($picture[1], $picture[2])) {
|
||||||
$body = str_replace($picture[0], '', $body);
|
$body = str_replace($picture[0], '', $body);
|
||||||
$attachments[$picture[1]] = [
|
$attachments[$picture[1]] = [
|
||||||
'uri-id' => $uriid, 'type' => self::IMAGE, 'url' => $picture[1],
|
'uri-id' => $uriid,
|
||||||
'preview' => $picture[2], 'description' => $picture[3]
|
'type' => self::IMAGE,
|
||||||
|
'url' => $picture[1],
|
||||||
|
'preview' => $picture[2],
|
||||||
|
'description' => $picture[3]
|
||||||
];
|
];
|
||||||
} elseif ($removepicturelinks) {
|
} elseif ($removepicturelinks) {
|
||||||
$body = str_replace($picture[0], '', $body);
|
$body = str_replace($picture[0], '', $body);
|
||||||
$attachments[$picture[1]] = [
|
$attachments[$picture[1]] = [
|
||||||
'uri-id' => $uriid, 'type' => self::UNKNOWN, 'url' => $picture[1],
|
'uri-id' => $uriid,
|
||||||
'preview' => $picture[2], 'description' => $picture[3]
|
'type' => self::UNKNOWN,
|
||||||
|
'url' => $picture[1],
|
||||||
|
'preview' => $picture[2],
|
||||||
|
'description' => $picture[3]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -644,20 +656,29 @@ class Media
|
||||||
$body = str_replace($picture[0], '', $body);
|
$body = str_replace($picture[0], '', $body);
|
||||||
$image = str_replace(['-1.', '-2.'], '-0.', $picture[2]);
|
$image = str_replace(['-1.', '-2.'], '-0.', $picture[2]);
|
||||||
$attachments[$image] = [
|
$attachments[$image] = [
|
||||||
'uri-id' => $uriid, 'type' => self::IMAGE, 'url' => $image,
|
'uri-id' => $uriid,
|
||||||
'preview' => $picture[2], 'description' => null
|
'type' => self::IMAGE,
|
||||||
|
'url' => $image,
|
||||||
|
'preview' => $picture[2],
|
||||||
|
'description' => null
|
||||||
];
|
];
|
||||||
} elseif (self::isLinkToPhoto($picture[1], $picture[2])) {
|
} elseif (self::isLinkToPhoto($picture[1], $picture[2])) {
|
||||||
$body = str_replace($picture[0], '', $body);
|
$body = str_replace($picture[0], '', $body);
|
||||||
$attachments[$picture[1]] = [
|
$attachments[$picture[1]] = [
|
||||||
'uri-id' => $uriid, 'type' => self::IMAGE, 'url' => $picture[1],
|
'uri-id' => $uriid,
|
||||||
'preview' => $picture[2], 'description' => null
|
'type' => self::IMAGE,
|
||||||
|
'url' => $picture[1],
|
||||||
|
'preview' => $picture[2],
|
||||||
|
'description' => null
|
||||||
];
|
];
|
||||||
} elseif ($removepicturelinks) {
|
} elseif ($removepicturelinks) {
|
||||||
$body = str_replace($picture[0], '', $body);
|
$body = str_replace($picture[0], '', $body);
|
||||||
$attachments[$picture[1]] = [
|
$attachments[$picture[1]] = [
|
||||||
'uri-id' => $uriid, 'type' => self::UNKNOWN, 'url' => $picture[1],
|
'uri-id' => $uriid,
|
||||||
'preview' => $picture[2], 'description' => null
|
'type' => self::UNKNOWN,
|
||||||
|
'url' => $picture[1],
|
||||||
|
'preview' => $picture[2],
|
||||||
|
'description' => null
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2037,9 +2037,15 @@ class Receiver
|
||||||
|
|
||||||
// Support for quoted posts (Pleroma, Fedibird and Misskey)
|
// Support for quoted posts (Pleroma, Fedibird and Misskey)
|
||||||
$object_data['quote-url'] = JsonLD::fetchElement($object, 'as:quoteUrl', '@id');
|
$object_data['quote-url'] = JsonLD::fetchElement($object, 'as:quoteUrl', '@id');
|
||||||
|
if (empty($object_data['quote-url'])) {
|
||||||
|
$object_data['quote-url'] = JsonLD::fetchElement($object, 'as:quoteUrl', '@value');
|
||||||
|
}
|
||||||
if (empty($object_data['quote-url'])) {
|
if (empty($object_data['quote-url'])) {
|
||||||
$object_data['quote-url'] = JsonLD::fetchElement($object, 'fedibird:quoteUri', '@id');
|
$object_data['quote-url'] = JsonLD::fetchElement($object, 'fedibird:quoteUri', '@id');
|
||||||
}
|
}
|
||||||
|
if (empty($object_data['quote-url'])) {
|
||||||
|
$object_data['quote-url'] = JsonLD::fetchElement($object, 'fedibird:quoteUri', '@value');
|
||||||
|
}
|
||||||
if (empty($object_data['quote-url'])) {
|
if (empty($object_data['quote-url'])) {
|
||||||
$object_data['quote-url'] = JsonLD::fetchElement($object, 'misskey:_misskey_quote', '@id');
|
$object_data['quote-url'] = JsonLD::fetchElement($object, 'misskey:_misskey_quote', '@id');
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue