123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Catalog\Model\View\Asset;
- use Magento\Catalog\Model\Product\Media\ConfigInterface;
- use Magento\Framework\Encryption\Encryptor;
- use Magento\Framework\Encryption\EncryptorInterface;
- use Magento\Framework\View\Asset\ContextInterface;
- use Magento\Framework\View\Asset\LocalInterface;
- /**
- * A locally available image file asset that can be referred with a file path
- *
- * This class is a value object with lazy loading of some of its data (content, physical file path)
- */
- class Image implements LocalInterface
- {
- /**
- * Image type of image (thumbnail,small_image,image,swatch_image,swatch_thumb)
- *
- * @var string
- */
- private $sourceContentType;
- /**
- * @var string
- */
- private $filePath;
- /**
- * @var string
- */
- private $contentType = 'image';
- /**
- * @var ContextInterface
- */
- private $context;
- /**
- * Misc image params depend on size, transparency, quality, watermark etc.
- *
- * @var array
- */
- private $miscParams;
- /**
- * @var ConfigInterface
- */
- private $mediaConfig;
- /**
- * @var EncryptorInterface
- */
- private $encryptor;
- /**
- * Image constructor.
- *
- * @param ConfigInterface $mediaConfig
- * @param ContextInterface $context
- * @param EncryptorInterface $encryptor
- * @param string $filePath
- * @param array $miscParams
- */
- public function __construct(
- ConfigInterface $mediaConfig,
- ContextInterface $context,
- EncryptorInterface $encryptor,
- $filePath,
- array $miscParams
- ) {
- if (isset($miscParams['image_type'])) {
- $this->sourceContentType = $miscParams['image_type'];
- unset($miscParams['image_type']);
- } else {
- $this->sourceContentType = $this->contentType;
- }
- $this->mediaConfig = $mediaConfig;
- $this->context = $context;
- $this->filePath = $filePath;
- $this->miscParams = $miscParams;
- $this->encryptor = $encryptor;
- }
- /**
- * {@inheritdoc}
- */
- public function getUrl()
- {
- return $this->context->getBaseUrl() . DIRECTORY_SEPARATOR . $this->getImageInfo();
- }
- /**
- * {@inheritdoc}
- */
- public function getContentType()
- {
- return $this->contentType;
- }
- /**
- * {@inheritdoc}
- */
- public function getPath()
- {
- return $this->context->getPath() . DIRECTORY_SEPARATOR . $this->getImageInfo();
- }
- /**
- * {@inheritdoc}
- */
- public function getSourceFile()
- {
- return $this->mediaConfig->getBaseMediaPath()
- . DIRECTORY_SEPARATOR . ltrim($this->getFilePath(), DIRECTORY_SEPARATOR);
- }
- /**
- * Get source content type
- *
- * @return string
- */
- public function getSourceContentType()
- {
- return $this->sourceContentType;
- }
- /**
- * {@inheritdoc}
- */
- public function getContent()
- {
- return null;
- }
- /**
- * {@inheritdoc}
- */
- public function getFilePath()
- {
- return $this->filePath;
- }
- /**
- * {@inheritdoc}
- * @return ContextInterface
- */
- public function getContext()
- {
- return $this->context;
- }
- /**
- * {@inheritdoc}
- */
- public function getModule()
- {
- return 'cache';
- }
- /**
- * Retrieve part of path based on misc params
- *
- * @return string
- */
- private function getMiscPath()
- {
- return $this->encryptor->hash(
- implode('_', $this->convertToReadableFormat($this->miscParams)),
- Encryptor::HASH_VERSION_MD5
- );
- }
- /**
- * Generate path from image info
- *
- * @return string
- */
- private function getImageInfo()
- {
- $path = $this->getModule()
- . DIRECTORY_SEPARATOR . $this->getMiscPath()
- . DIRECTORY_SEPARATOR . $this->getFilePath();
- return preg_replace('|\Q'. DIRECTORY_SEPARATOR . '\E+|', DIRECTORY_SEPARATOR, $path);
- }
- /**
- * Converting bool into a string representation
- * @param $miscParams
- * @return array
- */
- private function convertToReadableFormat($miscParams)
- {
- $miscParams['image_height'] = 'h:' . ($miscParams['image_height'] ?? 'empty');
- $miscParams['image_width'] = 'w:' . ($miscParams['image_width'] ?? 'empty');
- $miscParams['quality'] = 'q:' . ($miscParams['quality'] ?? 'empty');
- $miscParams['angle'] = 'r:' . ($miscParams['angle'] ?? 'empty');
- $miscParams['keep_aspect_ratio'] = (isset($miscParams['keep_aspect_ratio']) ? '' : 'non') . 'proportional';
- $miscParams['keep_frame'] = (isset($miscParams['keep_frame']) ? '' : 'no') . 'frame';
- $miscParams['keep_transparency'] = (isset($miscParams['keep_transparency']) ? '' : 'no') . 'transparency';
- $miscParams['constrain_only'] = (isset($miscParams['constrain_only']) ? 'do' : 'not') . 'constrainonly';
- $miscParams['background'] = isset($miscParams['background'])
- ? 'rgb' . implode(',', $miscParams['background'])
- : 'nobackground';
- return $miscParams;
- }
- }
|