addRule($ascii ? 'alpha:ascii' : 'alpha'); } /** * The field under validation must be entirely alpha-numeric characters, dashes, and underscores. * * @param bool $ascii * @return $this */ public function alphaDash(bool $ascii = false): static { return $this->addRule($ascii ? 'alpha_dash:ascii' : 'alpha_dash'); } /** * The field under validation must be entirely alpha-numeric characters. * * @param bool $ascii * @return $this */ public function alphaNumeric(bool $ascii = false): static { return $this->addRule($ascii ? 'alpha_num:ascii' : 'alpha_num'); } /** * The field under validation must be entirely ASCII characters. * * @return $this */ public function ascii(): static { return $this->addRule('ascii'); } /** * The field under validation must have a length between the given min and max (inclusive). * * @param int $min * @param int $max * @return $this */ public function between(int $min, int $max): static { return $this->addRule('between:'.$min.','.$max); } /** * The field under validation must not end with any of the given values. * * @param string ...$values * @return $this */ public function doesntEndWith(string ...$values): static { return $this->addRule('doesnt_end_with:'.implode(',', $values)); } /** * The field under validation must not start with any of the given values. * * @param string ...$values * @return $this */ public function doesntStartWith(string ...$values): static { return $this->addRule('doesnt_start_with:'.implode(',', $values)); } /** * The field under validation must end with one of the given values. * * @param string ...$values * @return $this */ public function endsWith(string ...$values): static { return $this->addRule('ends_with:'.implode(',', $values)); } /** * The field under validation must have an exact length. * * @param int $value * @return $this */ public function exactly(int $value): static { return $this->addRule('size:'.$value); } /** * The field under validation must be entirely lowercase. * * @return $this */ public function lowercase(): static { return $this->addRule('lowercase'); } /** * The field under validation must not exceed the given length. * * @param int $value * @return $this */ public function max(int $value): static { return $this->addRule('max:'.$value); } /** * The field under validation must have a minimum length. * * @param int $value * @return $this */ public function min(int $value): static { return $this->addRule('min:'.$value); } /** * The field under validation must start with one of the given values. * * @param string ...$values * @return $this */ public function startsWith(string ...$values): static { return $this->addRule('starts_with:'.implode(',', $values)); } /** * The field under validation must be entirely uppercase. * * @return $this */ public function uppercase(): static { return $this->addRule('uppercase'); } /** * Convert the rule to a validation string. */ public function __toString(): string { return implode('|', array_unique($this->constraints)); } /** * Add custom rules to the validation rules array. */ protected function addRule(array|string $rules): static { $this->constraints = array_merge($this->constraints, Arr::wrap($rules)); return $this; } }