2013-04-25 14:51:44 +04:00
|
|
|
<?php
|
2013-05-29 14:33:24 +04:00
|
|
|
namespace OC\Preview;
|
|
|
|
|
2013-05-29 15:11:43 +04:00
|
|
|
abstract class Provider {
|
2013-04-25 14:51:44 +04:00
|
|
|
private $options;
|
|
|
|
|
|
|
|
public function __construct($options) {
|
2014-11-27 21:40:23 +03:00
|
|
|
$this->options = $options;
|
2013-04-25 14:51:44 +04:00
|
|
|
}
|
2013-05-17 21:08:16 +04:00
|
|
|
|
2014-11-27 21:40:23 +03:00
|
|
|
/**
|
|
|
|
* @return string Regex with the mimetypes that are supported by this provider
|
|
|
|
*/
|
2013-04-25 14:51:44 +04:00
|
|
|
abstract public function getMimeType();
|
|
|
|
|
2014-07-30 18:29:18 +04:00
|
|
|
/**
|
|
|
|
* Check if a preview can be generated for $path
|
|
|
|
*
|
2014-11-27 21:40:23 +03:00
|
|
|
* @param \OC\Files\FileInfo $file
|
2014-07-30 18:29:18 +04:00
|
|
|
* @return bool
|
|
|
|
*/
|
2014-11-27 21:40:23 +03:00
|
|
|
public function isAvailable($file) {
|
2014-07-30 18:29:18 +04:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-04-25 14:51:44 +04:00
|
|
|
/**
|
2013-09-25 12:41:09 +04:00
|
|
|
* get thumbnail for file at path $path
|
|
|
|
* @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 19:30:58 +04:00
|
|
|
* @param bool $scalingup Disable/Enable upscaling of previews
|
2014-11-28 11:16:35 +03:00
|
|
|
* @param \OC\Files\View $fileview fileview object of user folder
|
2013-09-25 12:41:09 +04:00
|
|
|
* @return mixed
|
|
|
|
* false if no preview was generated
|
|
|
|
* OC_Image object of the preview
|
2013-04-25 14:51:44 +04:00
|
|
|
*/
|
2013-05-29 15:03:33 +04:00
|
|
|
abstract public function getThumbnail($path, $maxX, $maxY, $scalingup, $fileview);
|
2013-04-25 14:51:44 +04:00
|
|
|
}
|