TrimValidator.php 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\validators;
  8. use yii\helpers\Json;
  9. /**
  10. * This class converts the attribute value(s) to string(s) and strip characters.
  11. *
  12. * @since 2.0.46
  13. */
  14. class TrimValidator extends Validator
  15. {
  16. /**
  17. * @var string The list of characters to strip, with `..` can specify a range of characters.
  18. * For example, set '\/ ' to normalize path or namespace.
  19. */
  20. public $chars;
  21. /**
  22. * @var bool Whether the filter should be skipped if an array input is given.
  23. * If true and an array input is given, the filter will not be applied.
  24. */
  25. public $skipOnArray = false;
  26. /**
  27. * @inheritDoc
  28. */
  29. public $skipOnEmpty = false;
  30. /**
  31. * @inheritDoc
  32. */
  33. public function validateAttribute($model, $attribute)
  34. {
  35. $value = $model->$attribute;
  36. if (!$this->skipOnArray || !is_array($value)) {
  37. $model->$attribute = is_array($value)
  38. ? array_map([$this, 'trimValue'], $value)
  39. : $this->trimValue($value);
  40. }
  41. }
  42. /**
  43. * Converts given value to string and strips declared characters.
  44. *
  45. * @param mixed $value the value to strip
  46. * @return string
  47. */
  48. protected function trimValue($value)
  49. {
  50. return $this->isEmpty($value) ? '' : trim((string) $value, $this->chars ?: " \n\r\t\v\x00");
  51. }
  52. /**
  53. * @inheritDoc
  54. */
  55. public function clientValidateAttribute($model, $attribute, $view)
  56. {
  57. if ($this->skipOnArray && is_array($model->$attribute)) {
  58. return null;
  59. }
  60. ValidationAsset::register($view);
  61. $options = $this->getClientOptions($model, $attribute);
  62. return 'value = yii.validation.trim($form, attribute, ' . Json::htmlEncode($options) . ', value);';
  63. }
  64. /**
  65. * @inheritDoc
  66. */
  67. public function getClientOptions($model, $attribute)
  68. {
  69. return [
  70. 'skipOnArray' => (bool) $this->skipOnArray,
  71. 'skipOnEmpty' => (bool) $this->skipOnEmpty,
  72. 'chars' => $this->chars ?: false,
  73. ];
  74. }
  75. }