2025-03-17 22:21:38 +01:00
|
|
|
<?php
|
|
|
|
namespace Vichan\Service\Media;
|
|
|
|
|
2025-03-18 00:40:03 +01:00
|
|
|
use Vichan\Data\ImageMetadataResult;
|
|
|
|
use Vichan\Data\MagickMetadataReader;
|
|
|
|
|
2025-03-17 22:21:38 +01:00
|
|
|
|
2025-03-17 22:48:00 +01:00
|
|
|
/**
|
|
|
|
* Do not use this if you can.
|
|
|
|
*
|
|
|
|
* Some formats may contain no image or may contain multiple images. In these cases, getimagesize() might not be
|
|
|
|
* able to properly determine the image size. getimagesize() will return zero for width and height in these cases.
|
|
|
|
*
|
|
|
|
* getimagesize() is agnostic of any image metadata.
|
|
|
|
* If e.g. the Exif Orientation flag is set to a value which rotates the image by 90 or 270 degress, index 0 and 1
|
|
|
|
* are swapped, i.e. the contain the height and width, respectively.
|
|
|
|
*/
|
2025-03-18 00:40:03 +01:00
|
|
|
class DefaultImageMetadataReader implements ImageMetadataReader {
|
|
|
|
public function getMetadata(string $file_path): ImageMetadataResult {
|
2025-03-17 22:48:00 +01:00
|
|
|
$ret = \getimagesize($file_path, $info);
|
2025-03-17 22:21:38 +01:00
|
|
|
if ($ret === false) {
|
|
|
|
throw new \RuntimeException("Could not read image sizes of '$file_path'");
|
|
|
|
}
|
2025-03-17 22:48:00 +01:00
|
|
|
if ($ret[2] == \IMAGETYPE_UNKNOWN) {
|
|
|
|
throw new \RuntimeException("Error '$file_path' is not an image");
|
|
|
|
}
|
2025-03-18 00:40:03 +01:00
|
|
|
return new ImageMetadataResult($ret[0], $ret[1], $ret['mime']);
|
2025-03-17 22:21:38 +01:00
|
|
|
}
|
|
|
|
}
|