Beispiel #1
0
 /**
  *
  */
 public function generate()
 {
     $errorImage = PIMCORE_PATH . '/static6/img/filetype-not-supported.png';
     $deferred = false;
     $generated = false;
     if (!$this->asset) {
         $this->filesystemPath = $errorImage;
     } elseif (!$this->filesystemPath) {
         $cs = $this->asset->getCustomSetting("image_thumbnail_time");
         $im = $this->asset->getCustomSetting("image_thumbnail_asset");
         if ($im || $this->imageAsset) {
             if ($this->imageAsset) {
                 $im = Model\Asset::getById($im);
             }
             if ($im instanceof Image) {
                 return $im->getThumbnail($this->getConfig());
             }
         }
         $timeOffset = $this->timeOffset;
         if (!$this->timeOffset && $cs) {
             $timeOffset = $cs;
         }
         // fallback
         if (!$timeOffset) {
             $timeOffset = ceil($this->asset->getDuration() / 3);
         }
         $converter = \Pimcore\Video::getInstance();
         $converter->load($this->asset->getFileSystemPath());
         $path = PIMCORE_TEMPORARY_DIRECTORY . "/video-image-cache/video_" . $this->asset->getId() . "__thumbnail_" . $timeOffset . ".png";
         if (!is_dir(dirname($path))) {
             File::mkdir(dirname($path));
         }
         if (!is_file($path)) {
             $lockKey = "video_image_thumbnail_" . $this->asset->getId() . "_" . $timeOffset;
             Model\Tool\Lock::acquire($lockKey);
             // after we got the lock, check again if the image exists in the meantime - if not - generate it
             if (!is_file($path)) {
                 $converter->saveImage($path, $timeOffset);
                 $generated = true;
             }
             Model\Tool\Lock::release($lockKey);
         }
         if ($this->getConfig()) {
             $this->getConfig()->setFilenameSuffix("time-" . $timeOffset);
             try {
                 $path = Image\Thumbnail\Processor::process($this->asset, $this->getConfig(), $path, $deferred, true, $generated);
             } catch (\Exception $e) {
                 \Logger::error("Couldn't create image-thumbnail of video " . $this->asset->getRealFullPath());
                 \Logger::error($e);
                 $path = $errorImage;
             }
         }
         $this->filesystemPath = $path;
         \Pimcore::getEventManager()->trigger("asset.video.image-thumbnail", $this, ["deferred" => $deferred, "generated" => $generated]);
     }
 }
Beispiel #2
0
 /**
  *
  */
 public function generate()
 {
     $errorImage = PIMCORE_PATH . '/static6/img/filetype-not-supported.png';
     $generated = false;
     if (!$this->asset) {
         $this->filesystemPath = $errorImage;
     } elseif (!$this->filesystemPath) {
         $config = $this->getConfig();
         $config->setName("document_" . $config->getName() . "-" . $this->page);
         try {
             $path = null;
             if (!$this->deferred) {
                 $converter = \Pimcore\Document::getInstance();
                 $converter->load($this->asset->getFileSystemPath());
                 $path = PIMCORE_TEMPORARY_DIRECTORY . "/document-image-cache/document_" . $this->asset->getId() . "__thumbnail_" . $this->page . ".png";
                 if (!is_dir(dirname($path))) {
                     \Pimcore\File::mkdir(dirname($path));
                 }
                 $lockKey = "document-thumbnail-" . $this->asset->getId() . "-" . $this->page;
                 if (!is_file($path) && !Model\Tool\Lock::isLocked($lockKey)) {
                     Model\Tool\Lock::lock($lockKey);
                     $converter->saveImage($path, $this->page);
                     $generated = true;
                     Model\Tool\Lock::release($lockKey);
                 } elseif (Model\Tool\Lock::isLocked($lockKey)) {
                     return "/pimcore/static6/img/please-wait.png";
                 }
             }
             if ($config) {
                 $path = Image\Thumbnail\Processor::process($this->asset, $config, $path, $this->deferred, true, $generated);
             }
             $this->filesystemPath = $path;
         } catch (\Exception $e) {
             Logger::error("Couldn't create image-thumbnail of document " . $this->asset->getRealFullPath());
             Logger::error($e);
             $this->filesystemPath = $errorImage;
         }
         \Pimcore::getEventManager()->trigger("asset.document.image-thumbnail", $this, ["deferred" => $this->deferred, "generated" => $generated]);
     }
 }