123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 |
- <?php
- /**
- * @link https://www.yiiframework.com/
- * @copyright Copyright (c) 2008 Yii Software LLC
- * @license https://www.yiiframework.com/license/
- */
- namespace yii\validators;
- use Yii;
- use yii\helpers\Json;
- use yii\web\UploadedFile;
- /**
- * ImageValidator verifies if an attribute is receiving a valid image.
- *
- * @author Taras Gudz <gudz.taras@gmail.com>
- * @since 2.0
- */
- class ImageValidator extends FileValidator
- {
- /**
- * @var string the error message used when the uploaded file is not an image.
- * You may use the following tokens in the message:
- *
- * - {attribute}: the attribute name
- * - {file}: the uploaded file name
- */
- public $notImage;
- /**
- * @var int|null the minimum width in pixels.
- * Defaults to null, meaning no limit.
- * @see underWidth for the customized message used when image width is too small.
- */
- public $minWidth;
- /**
- * @var int|null the maximum width in pixels.
- * Defaults to null, meaning no limit.
- * @see overWidth for the customized message used when image width is too big.
- */
- public $maxWidth;
- /**
- * @var int|null the minimum height in pixels.
- * Defaults to null, meaning no limit.
- * @see underHeight for the customized message used when image height is too small.
- */
- public $minHeight;
- /**
- * @var int|null the maximum width in pixels.
- * Defaults to null, meaning no limit.
- * @see overHeight for the customized message used when image height is too big.
- */
- public $maxHeight;
- /**
- * @var string the error message used when the image is under [[minWidth]].
- * You may use the following tokens in the message:
- *
- * - {attribute}: the attribute name
- * - {file}: the uploaded file name
- * - {limit}: the value of [[minWidth]]
- */
- public $underWidth;
- /**
- * @var string the error message used when the image is over [[maxWidth]].
- * You may use the following tokens in the message:
- *
- * - {attribute}: the attribute name
- * - {file}: the uploaded file name
- * - {limit}: the value of [[maxWidth]]
- */
- public $overWidth;
- /**
- * @var string the error message used when the image is under [[minHeight]].
- * You may use the following tokens in the message:
- *
- * - {attribute}: the attribute name
- * - {file}: the uploaded file name
- * - {limit}: the value of [[minHeight]]
- */
- public $underHeight;
- /**
- * @var string the error message used when the image is over [[maxHeight]].
- * You may use the following tokens in the message:
- *
- * - {attribute}: the attribute name
- * - {file}: the uploaded file name
- * - {limit}: the value of [[maxHeight]]
- */
- public $overHeight;
- /**
- * {@inheritdoc}
- */
- public function init()
- {
- parent::init();
- if ($this->notImage === null) {
- $this->notImage = Yii::t('yii', 'The file "{file}" is not an image.');
- }
- if ($this->underWidth === null) {
- $this->underWidth = Yii::t('yii', 'The image "{file}" is too small. The width cannot be smaller than {limit, number} {limit, plural, one{pixel} other{pixels}}.');
- }
- if ($this->underHeight === null) {
- $this->underHeight = Yii::t('yii', 'The image "{file}" is too small. The height cannot be smaller than {limit, number} {limit, plural, one{pixel} other{pixels}}.');
- }
- if ($this->overWidth === null) {
- $this->overWidth = Yii::t('yii', 'The image "{file}" is too large. The width cannot be larger than {limit, number} {limit, plural, one{pixel} other{pixels}}.');
- }
- if ($this->overHeight === null) {
- $this->overHeight = Yii::t('yii', 'The image "{file}" is too large. The height cannot be larger than {limit, number} {limit, plural, one{pixel} other{pixels}}.');
- }
- }
- /**
- * {@inheritdoc}
- */
- protected function validateValue($value)
- {
- $result = parent::validateValue($value);
- return empty($result) ? $this->validateImage($value) : $result;
- }
- /**
- * Validates an image file.
- * @param UploadedFile $image uploaded file passed to check against a set of rules
- * @return array|null the error message and the parameters to be inserted into the error message.
- * Null should be returned if the data is valid.
- */
- protected function validateImage($image)
- {
- if (false === ($imageInfo = getimagesize($image->tempName))) {
- return [$this->notImage, ['file' => $image->name]];
- }
- list($width, $height) = $imageInfo;
- if ($width == 0 || $height == 0) {
- return [$this->notImage, ['file' => $image->name]];
- }
- if ($this->minWidth !== null && $width < $this->minWidth) {
- return [$this->underWidth, ['file' => $image->name, 'limit' => $this->minWidth]];
- }
- if ($this->minHeight !== null && $height < $this->minHeight) {
- return [$this->underHeight, ['file' => $image->name, 'limit' => $this->minHeight]];
- }
- if ($this->maxWidth !== null && $width > $this->maxWidth) {
- return [$this->overWidth, ['file' => $image->name, 'limit' => $this->maxWidth]];
- }
- if ($this->maxHeight !== null && $height > $this->maxHeight) {
- return [$this->overHeight, ['file' => $image->name, 'limit' => $this->maxHeight]];
- }
- return null;
- }
- /**
- * {@inheritdoc}
- */
- public function clientValidateAttribute($model, $attribute, $view)
- {
- ValidationAsset::register($view);
- $options = $this->getClientOptions($model, $attribute);
- return 'yii.validation.image(attribute, messages, ' . Json::htmlEncode($options) . ', deferred);';
- }
- /**
- * {@inheritdoc}
- */
- public function getClientOptions($model, $attribute)
- {
- $options = parent::getClientOptions($model, $attribute);
- $label = $model->getAttributeLabel($attribute);
- if ($this->notImage !== null) {
- $options['notImage'] = $this->formatMessage($this->notImage, [
- 'attribute' => $label,
- ]);
- }
- if ($this->minWidth !== null) {
- $options['minWidth'] = $this->minWidth;
- $options['underWidth'] = $this->formatMessage($this->underWidth, [
- 'attribute' => $label,
- 'limit' => $this->minWidth,
- ]);
- }
- if ($this->maxWidth !== null) {
- $options['maxWidth'] = $this->maxWidth;
- $options['overWidth'] = $this->formatMessage($this->overWidth, [
- 'attribute' => $label,
- 'limit' => $this->maxWidth,
- ]);
- }
- if ($this->minHeight !== null) {
- $options['minHeight'] = $this->minHeight;
- $options['underHeight'] = $this->formatMessage($this->underHeight, [
- 'attribute' => $label,
- 'limit' => $this->minHeight,
- ]);
- }
- if ($this->maxHeight !== null) {
- $options['maxHeight'] = $this->maxHeight;
- $options['overHeight'] = $this->formatMessage($this->overHeight, [
- 'attribute' => $label,
- 'limit' => $this->maxHeight,
- ]);
- }
- return $options;
- }
- }
|