2013-04-25 06:51:44 -04:00
|
|
|
<?php
|
2024-05-23 03:26:56 -04:00
|
|
|
|
2015-03-26 06:44:34 -04:00
|
|
|
/**
|
2024-05-23 03:26:56 -04:00
|
|
|
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
|
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
|
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
2015-03-26 06:44:34 -04:00
|
|
|
*/
|
2013-05-29 06:33:24 -04:00
|
|
|
namespace OC\Preview;
|
|
|
|
|
|
2015-03-12 06:59:45 -04:00
|
|
|
use OCP\Preview\IProvider;
|
|
|
|
|
|
|
|
|
|
abstract class Provider implements IProvider {
|
2013-04-25 06:51:44 -04:00
|
|
|
private $options;
|
|
|
|
|
|
2015-03-12 07:08:31 -04:00
|
|
|
/**
|
|
|
|
|
* Constructor
|
|
|
|
|
*
|
|
|
|
|
* @param array $options
|
|
|
|
|
*/
|
|
|
|
|
public function __construct(array $options = []) {
|
2014-11-27 13:40:23 -05:00
|
|
|
$this->options = $options;
|
2013-04-25 06:51:44 -04:00
|
|
|
}
|
2013-05-17 13:08:16 -04:00
|
|
|
|
2014-11-27 13:40:23 -05:00
|
|
|
/**
|
|
|
|
|
* @return string Regex with the mimetypes that are supported by this provider
|
|
|
|
|
*/
|
2013-04-25 06:51:44 -04:00
|
|
|
abstract public function getMimeType();
|
|
|
|
|
|
2014-07-30 10:29:18 -04:00
|
|
|
/**
|
|
|
|
|
* Check if a preview can be generated for $path
|
|
|
|
|
*
|
2015-03-11 11:43:00 -04:00
|
|
|
* @param \OCP\Files\FileInfo $file
|
2014-07-30 10:29:18 -04:00
|
|
|
* @return bool
|
|
|
|
|
*/
|
2015-03-12 07:20:39 -04:00
|
|
|
public function isAvailable(\OCP\Files\FileInfo $file) {
|
2014-07-30 10:29:18 -04:00
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2013-04-25 06:51:44 -04:00
|
|
|
/**
|
2015-06-06 10:21:36 -04:00
|
|
|
* Generates thumbnail which fits in $maxX and $maxY and keeps the aspect ratio, for file at path $path
|
|
|
|
|
*
|
2013-09-25 04:41:09 -04:00
|
|
|
* @param string $path Path of file
|
|
|
|
|
* @param int $maxX The maximum X size of the thumbnail. It can be smaller depending on the shape of the image
|
|
|
|
|
* @param int $maxY The maximum Y size of the thumbnail. It can be smaller depending on the shape of the image
|
2014-02-06 10:30:58 -05:00
|
|
|
* @param bool $scalingup Disable/Enable upscaling of previews
|
2014-11-28 03:16:35 -05:00
|
|
|
* @param \OC\Files\View $fileview fileview object of user folder
|
2015-03-13 05:10:11 -04:00
|
|
|
* @return bool|\OCP\IImage false if no preview was generated
|
2013-04-25 06:51:44 -04:00
|
|
|
*/
|
2013-05-29 07:03:33 -04:00
|
|
|
abstract public function getThumbnail($path, $maxX, $maxY, $scalingup, $fileview);
|
2013-04-25 06:51:44 -04:00
|
|
|
}
|