mirror of
https://github.com/nextcloud/server.git
synced 2026-06-09 00:32:29 -04:00
fix: catch errors in id3parser library
We use a forked version of getID3 to read embedded images from mp3 files to use them as previews. If the library is unable to extract a image or fails on something different we should handle it properly. Signed-off-by: Daniel Kesselberg <mail@danielkesselberg.de>
This commit is contained in:
parent
b953fd7b0a
commit
0670ae607b
1 changed files with 13 additions and 2 deletions
|
|
@ -32,6 +32,7 @@ use ID3Parser\ID3Parser;
|
|||
|
||||
use OCP\Files\File;
|
||||
use OCP\IImage;
|
||||
use Psr\Log\LoggerInterface;
|
||||
|
||||
class MP3 extends ProviderV2 {
|
||||
/**
|
||||
|
|
@ -48,8 +49,18 @@ class MP3 extends ProviderV2 {
|
|||
$getID3 = new ID3Parser();
|
||||
|
||||
$tmpPath = $this->getLocalFile($file);
|
||||
$tags = $getID3->analyze($tmpPath);
|
||||
$this->cleanTmpFiles();
|
||||
try {
|
||||
$tags = $getID3->analyze($tmpPath);
|
||||
} catch (\Throwable $e) {
|
||||
\OC::$server->get(LoggerInterface::class)->info($e->getMessage(), [
|
||||
'exception' => $e,
|
||||
'app' => 'core',
|
||||
]);
|
||||
return null;
|
||||
} finally {
|
||||
$this->cleanTmpFiles();
|
||||
}
|
||||
|
||||
$picture = isset($tags['id3v2']['APIC'][0]['data']) ? $tags['id3v2']['APIC'][0]['data'] : null;
|
||||
if (is_null($picture) && isset($tags['id3v2']['PIC'][0]['data'])) {
|
||||
$picture = $tags['id3v2']['PIC'][0]['data'];
|
||||
|
|
|
|||
Loading…
Reference in a new issue