summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCôme Chilliet <come.chilliet@nextcloud.com>2021-12-02 11:06:17 +0100
committerCôme Chilliet <come.chilliet@nextcloud.com>2021-12-14 11:20:13 +0100
commit3f10cf89965f2938d7bd3d00033890ab0222600c (patch)
tree0085affe7a370fdf6819fa47b1044621dd50ab38
parent050b680d1d3939fb142693feac0b904663a18e2a (diff)
downloadnextcloud-server-3f10cf89965f2938d7bd3d00033890ab0222600c.tar.gz
nextcloud-server-3f10cf89965f2938d7bd3d00033890ab0222600c.zip
Avoid calling image* methods on boolean
This avoids fatal errors on PHP>=8, and warnings on older versions. Log should also be clearer. Signed-off-by: Côme Chilliet <come.chilliet@nextcloud.com>
-rw-r--r--lib/private/legacy/OC_Image.php41
1 files changed, 27 insertions, 14 deletions
diff --git a/lib/private/legacy/OC_Image.php b/lib/private/legacy/OC_Image.php
index fc2eff20065..dcc65af358e 100644
--- a/lib/private/legacy/OC_Image.php
+++ b/lib/private/legacy/OC_Image.php
@@ -6,6 +6,7 @@
* @author Bart Visscher <bartv@thisnet.nl>
* @author Björn Schießle <bjoern@schiessle.org>
* @author Byron Marohn <combustible@live.com>
+ * @author Côme Chilliet <come.chilliet@nextcloud.com>
* @author Christopher Schäpers <kondou@ts.unde.re>
* @author Christoph Wurst <christoph@winzerhof-wurst.at>
* @author Georg Ehrke <oc.list@georgehrke.com>
@@ -46,7 +47,7 @@ use OCP\IImage;
* Class for basic image manipulation
*/
class OC_Image implements \OCP\IImage {
- /** @var false|resource */
+ /** @var false|resource|\GdImage */
protected $resource = false; // tmp resource.
/** @var int */
protected $imageType = IMAGETYPE_PNG; // Default to png if file type isn't evident.
@@ -68,7 +69,7 @@ class OC_Image implements \OCP\IImage {
/**
* Constructor.
*
- * @param resource|string $imageRef The path to a local file, a base64 encoded string or a resource created by
+ * @param resource|string|\GdImage $imageRef The path to a local file, a base64 encoded string or a resource created by
* an imagecreate* function.
* @param \OCP\ILogger $logger
* @param \OCP\IConfig $config
@@ -98,7 +99,7 @@ class OC_Image implements \OCP\IImage {
*
* @return bool
*/
- public function valid() { // apparently you can't name a method 'empty'...
+ public function valid() {
if (is_resource($this->resource)) {
return true;
}
@@ -327,7 +328,7 @@ class OC_Image implements \OCP\IImage {
}
/**
- * @return resource|\GdImage Returns the image resource in any.
+ * @return false|resource|\GdImage Returns the image resource if any
*/
public function resource() {
return $this->resource;
@@ -469,6 +470,10 @@ class OC_Image implements \OCP\IImage {
* @return bool
*/
public function fixOrientation() {
+ if (!$this->valid()) {
+ $this->logger->error(__METHOD__ . '(): No image loaded', ['app' => 'core']);
+ return false;
+ }
$o = $this->getOrientation();
$this->logger->debug('OC_Image->fixOrientation() Orientation: ' . $o, ['app' => 'core']);
$rotate = 0;
@@ -876,6 +881,10 @@ class OC_Image implements \OCP\IImage {
* @return bool
*/
public function resize($maxSize) {
+ if (!$this->valid()) {
+ $this->logger->error(__METHOD__ . '(): No image loaded', ['app' => 'core']);
+ return false;
+ }
$result = $this->resizeNew($maxSize);
imagedestroy($this->resource);
$this->resource = $result;
@@ -912,6 +921,10 @@ class OC_Image implements \OCP\IImage {
* @return bool
*/
public function preciseResize(int $width, int $height): bool {
+ if (!$this->valid()) {
+ $this->logger->error(__METHOD__ . '(): No image loaded', ['app' => 'core']);
+ return false;
+ }
$result = $this->preciseResizeNew($width, $height);
imagedestroy($this->resource);
$this->resource = $result;
@@ -991,9 +1004,8 @@ class OC_Image implements \OCP\IImage {
$targetHeight = $height;
}
$process = imagecreatetruecolor($targetWidth, $targetHeight);
- if ($process == false) {
+ if ($process === false) {
$this->logger->error('OC_Image->centerCrop, Error creating true color image', ['app' => 'core']);
- imagedestroy($process);
return false;
}
@@ -1005,9 +1017,8 @@ class OC_Image implements \OCP\IImage {
}
imagecopyresampled($process, $this->resource, 0, 0, $x, $y, $targetWidth, $targetHeight, $width, $height);
- if ($process == false) {
+ if ($process === false) {
$this->logger->error('OC_Image->centerCrop, Error re-sampling process image ' . $width . 'x' . $height, ['app' => 'core']);
- imagedestroy($process);
return false;
}
imagedestroy($this->resource);
@@ -1025,6 +1036,10 @@ class OC_Image implements \OCP\IImage {
* @return bool for success or failure
*/
public function crop(int $x, int $y, int $w, int $h): bool {
+ if (!$this->valid()) {
+ $this->logger->error(__METHOD__ . '(): No image loaded', ['app' => 'core']);
+ return false;
+ }
$result = $this->cropNew($x, $y, $w, $h);
imagedestroy($this->resource);
$this->resource = $result;
@@ -1038,7 +1053,7 @@ class OC_Image implements \OCP\IImage {
* @param int $y Vertical position
* @param int $w Width
* @param int $h Height
- * @return resource | bool
+ * @return resource|\GdImage|false
*/
public function cropNew(int $x, int $y, int $w, int $h) {
if (!$this->valid()) {
@@ -1046,9 +1061,8 @@ class OC_Image implements \OCP\IImage {
return false;
}
$process = imagecreatetruecolor($w, $h);
- if ($process == false) {
+ if ($process === false) {
$this->logger->error(__METHOD__ . '(): Error creating true color image', ['app' => 'core']);
- imagedestroy($process);
return false;
}
@@ -1060,9 +1074,8 @@ class OC_Image implements \OCP\IImage {
}
imagecopyresampled($process, $this->resource, 0, 0, $x, $y, $w, $h, $w, $h);
- if ($process == false) {
+ if ($process === false) {
$this->logger->error(__METHOD__ . '(): Error re-sampling process image ' . $w . 'x' . $h, ['app' => 'core']);
- imagedestroy($process);
return false;
}
return $process;
@@ -1179,7 +1192,7 @@ class OC_Image implements \OCP\IImage {
if ($this->valid()) {
imagedestroy($this->resource);
}
- $this->resource = null;
+ $this->resource = false;
}
public function __destruct() {