InlineValidator.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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. /**
  9. * InlineValidator represents a validator which is defined as a method in the object being validated.
  10. *
  11. * @author Qiang Xue <qiang.xue@gmail.com>
  12. * @since 2.0
  13. */
  14. class InlineValidator extends Validator
  15. {
  16. /**
  17. * @var string|callable an anonymous function or the name of a model class method that will be
  18. * called to perform the actual validation. The signature of the method should be like the following:
  19. *
  20. * ```php
  21. * function (string $attribute, mixed $params, InlineValidator $validator, mixed $current): bool {
  22. * }
  23. * ```
  24. *
  25. * - `$attribute` is the name of the attribute to be validated
  26. * - `$params` contains the value of [[params]] that you specify when declaring the inline validation rule
  27. * - `$validator` is a reference to related [[InlineValidator]] object. This parameter is available since version 2.0.11
  28. * - `$current` is the attribute value. This parameter is available since version 2.0.36
  29. */
  30. public $method;
  31. /**
  32. * @var mixed additional parameters that are passed to the validation method
  33. */
  34. public $params;
  35. /**
  36. * @var string|\Closure an anonymous function or the name of a model class method that returns the client validation code.
  37. * The signature of the method should be like the following:
  38. *
  39. * ```php
  40. * function (string $attribute, mixed $params, InlineValidator $validator, mixed $current, View $view): string
  41. * {
  42. * // $view->registerJs('JS validation function');
  43. * // or \app\assets\ValidationAsset::register($view);
  44. * return "calling JS validation function";
  45. * }
  46. * ```
  47. *
  48. * Please refer to [[clientValidateAttribute()]] and [guide](guide:input-validation#client-side-validation) for details on how
  49. * to return client validation code.
  50. */
  51. public $clientValidate;
  52. /**
  53. * @var mixed the value of attribute being currently validated.
  54. * @since 2.0.36
  55. */
  56. public $current;
  57. /**
  58. * {@inheritdoc}
  59. */
  60. public function validateAttribute($model, $attribute)
  61. {
  62. $method = $this->method;
  63. if (is_string($method)) {
  64. $method = [$model, $method];
  65. } elseif ($method instanceof \Closure) {
  66. $method = $this->method->bindTo($model);
  67. }
  68. $current = $this->current;
  69. if ($current === null) {
  70. $current = $model->$attribute;
  71. }
  72. $method($attribute, $this->params, $this, $current);
  73. }
  74. /**
  75. * {@inheritdoc}
  76. */
  77. public function clientValidateAttribute($model, $attribute, $view)
  78. {
  79. if ($this->clientValidate !== null) {
  80. $method = $this->clientValidate;
  81. if (is_string($method)) {
  82. $method = [$model, $method];
  83. } elseif ($method instanceof \Closure) {
  84. $method = $method->bindTo($model);
  85. }
  86. $current = $this->current;
  87. if ($current === null) {
  88. $current = $model->$attribute;
  89. }
  90. return $method($attribute, $this->params, $this, $current, $view);
  91. }
  92. return null;
  93. }
  94. }