forked from GNUsocial/gnu-social
[Embed] Fix use of undefined img_data
Got error 'PHP message: PHP Notice: Undefined variable: img_data in /var/www/html/plugins/Embed/EmbedPlugin.php on line 544'
This commit is contained in:
parent
2e66cbeb60
commit
c03f659efb
@ -132,8 +132,8 @@ class EmbedPlugin extends Plugin
|
|||||||
|
|
||||||
if (substr($info->image, 0, 4) === 'data') {
|
if (substr($info->image, 0, 4) === 'data') {
|
||||||
// Inline image
|
// Inline image
|
||||||
$img_data = base64_decode(substr($info->image, stripos($info->image, 'base64,') + 7));
|
$imgData = base64_decode(substr($info->image, stripos($info->image, 'base64,') + 7));
|
||||||
list($filename, , ) = $this->validateAndWriteImage($img_data);
|
list($filename, , ) = $this->validateAndWriteImage($imgData);
|
||||||
// Use a file URI for images, as file_embed can't store a filename
|
// Use a file URI for images, as file_embed can't store a filename
|
||||||
$metadata->thumbnail_url = 'file://' . File_thumbnail::path($filename);
|
$metadata->thumbnail_url = 'file://' . File_thumbnail::path($filename);
|
||||||
} else {
|
} else {
|
||||||
@ -541,7 +541,7 @@ class EmbedPlugin extends Plugin
|
|||||||
$fullpath = File_thumbnail::path($filename);
|
$fullpath = File_thumbnail::path($filename);
|
||||||
// Write the file to disk. Throw Exception on failure
|
// Write the file to disk. Throw Exception on failure
|
||||||
if (!file_exists($fullpath)) {
|
if (!file_exists($fullpath)) {
|
||||||
if (strpos($fullpath, INSTALLDIR) !== 0 || file_put_contents($fullpath, $img_data) === false) {
|
if (strpos($fullpath, INSTALLDIR) !== 0 || file_put_contents($fullpath, $imgData) === false) {
|
||||||
throw new ServerException(_('Could not write downloaded file to disk.'));
|
throw new ServerException(_('Could not write downloaded file to disk.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -575,7 +575,7 @@ class EmbedPlugin extends Plugin
|
|||||||
"but encountered error: {$err}");
|
"but encountered error: {$err}");
|
||||||
throw $err;
|
throw $err;
|
||||||
} finally {
|
} finally {
|
||||||
unset($img_data);
|
unset($imgData);
|
||||||
}
|
}
|
||||||
|
|
||||||
return [$filename, $width, $height];
|
return [$filename, $width, $height];
|
||||||
@ -620,6 +620,8 @@ class EmbedPlugin extends Plugin
|
|||||||
" but the upload limit is " . $max_size . " so we aborted.");
|
" but the upload limit is " . $max_size . " so we aborted.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
} catch (Exception $err) {
|
} catch (Exception $err) {
|
||||||
common_debug("Could not determine size of remote image, aborted local storage.");
|
common_debug("Could not determine size of remote image, aborted local storage.");
|
||||||
@ -633,10 +635,19 @@ class EmbedPlugin extends Plugin
|
|||||||
$thumbnail->file_id,
|
$thumbnail->file_id,
|
||||||
$url
|
$url
|
||||||
));
|
));
|
||||||
|
try {
|
||||||
$imgData = HTTPClient::quickGet($url);
|
$imgData = HTTPClient::quickGet($url);
|
||||||
|
if (isset($imgData)) {
|
||||||
list($filename, $width, $height) = $this->validateAndWriteImage($imgData, $url, $headers,
|
list($filename, $width, $height) = $this->validateAndWriteImage($imgData, $url, $headers,
|
||||||
$thumbnail->file_id);
|
$thumbnail->file_id);
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedMediaException('HTTPClient returned an empty result');
|
||||||
|
}
|
||||||
|
} catch(UnsupportedMediaException $e) {
|
||||||
|
// Couldn't find anything that looks like an image, nothing to do
|
||||||
|
common_debug("Embed was not able to find an image for URL `{$url}`: " . $e->getMessage());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
Loading…
Reference in New Issue
Block a user