/**
* Validate a given attribute against a rule.
*
* @param string $attribute
* @param string $rule
* @return void
*/
protected function validate($attribute, $rule)
{// validate a given attribute against a rule.
list($rule, $parameters) = $this->parseRule($rule);//list function to get the
if ($rule == '') {
return;
}// if no rule
// First we will get the numeric keys for the given attribute in case the field is nested in
// an array. Then we determine if the given rule accepts other field names as parameters.
// If so, we will replace any asterisks found in the parameters with the numeric keys.
if (($keys = $this->getNumericKeys($attribute)) &&
$this->dependsOnOtherFields($rule)) {//get number and depends
$parameters = $this->replaceAsterisksInParameters($parameters, $keys);
}// a normal logic function
// We will get the value for the given attribute from the array of data and then
// verify that the attribute is indeed validatable. Unless the rule implies
// that the attribute is required, rules are not run for missing values.
$value = $this->getValue($attribute);
// We will get the value for the given attribute from the array of data and then
// verify that the attribute is indeed vaidatable.Unless the rule implies
// that the attribute is required,rules are not run for missing values.
$validatable = $this->isValidatable($rule, $attribute, $value);
// determine validatable
$method = "validate{$rule}";// get method way
if ($validatable && ! $this->$method($attribute, $value, $parameters, $this)) {
$this->addFailure($attribute, $rule, $parameters);
}// determine all
}
/**
* Returns the data which was valid.
*
* @return array
*/
public function valid()
{
if (! $this->messages) {
$this->passes();
}
return array_diff_key($this->data, $this->messages()->toArray());
}// change it is a real valid data
/**
* Returns the data which was invalid.
*
* @return array
*/
public function invalid()
{
if (! $this->messages) {
$this->passes();
}//if do not has messages get passes
return array_intersect_key($this->data, $this->messages()->toArray());// return array_intersect_key
}// a invalid method
/**
* Get the value of a given attribute.
*
* @param string $attribute
* @return mixed
*/
protected function getValue($attribute)
{
if (! is_null($value = Arr::get($this->data, $attribute))) {// type1
return $value;// return value
} elseif (! is_null($value = Arr::get($this->files, $attribute))) {//type2
return $value;// return value
}
}//Get the value of a given attribute
/**
* Determine if the attribute is validatable.
*
* @param string $rule
* @param string $attribute
* @param mixed $value
* @return bool
*/
protected function isValidatable($rule, $attribute, $value)
{
return $this->presentOrRuleIsImplicit($rule, $attribute, $value) &&
$this->passesOptionalCheck($attribute) &&
$this->hasNotFailedPreviousRuleIfPresenceRule($rule, $attribute);
//three type determine this value.
}//determine if the attribute is validatable.
/**
* Determine if the field is present, or the rule implies required.
*
* @param string $rule
* @param string $attribute
* @param mixed $value
* @return bool
*/
protected function presentOrRuleIsImplicit($rule, $attribute, $value)
{
return $this->validateRequired($attribute, $value) || $this->isImplicit($rule);
// this validateRequired
}//Determine if the field is present, or the rule implies required.
/**
* Determine if the attribute passes any optional check.
*
* @param string $attribute
* @return bool
*/
protected function passesOptionalCheck($attribute)
{
if ($this->hasRule($attribute, ['Sometimes'])) {
return array_key_exists($attribute, Arr::dot($this->data))
|| in_array($attribute, array_keys($this->data))
|| array_key_exists($attribute, $this->files);
}// this->hasRule($attribute)
return true;
}// passes Optional Check
/**
* Determine if a given rule implies the attribute is required.
*
* @param string $rule
* @return bool
*/
protected function isImplicit($rule)
{
return in_array($rule, $this->implicitRules);
}// check it is a implicit
// in_array
// sorry today,we need to make a very important PPT, so done.