Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Laravel: validate an integer field that needs to be greater than another

I have two fields that are optional only if both aren't present:

$rules = [
  'initial_page' => 'required_with:end_page|integer|min:1|digits_between: 1,5',
  'end_page' => 'required_with:initial_page|integer|min:2|digits_between:1,5'
]; 

Now, end_page needs to be greater than initial_page. How include this filter?

like image 339
Alexandre Thebaldi Avatar asked Aug 16 '15 15:08

Alexandre Thebaldi


3 Answers

There is no built-in validation that would let you compare field values like that in Laravel, so you'll need to implement a custom validator, that will let you reuse validation where needed. Luckily, Laravel makes writing custom validator really easy.

Start with defining new validator in yor AppServiceProvider:

class AppServiceProvider extends ServiceProvider
{
  public function boot()
  {
    Validator::extend('greater_than_field', function($attribute, $value, $parameters, $validator) {
      $min_field = $parameters[0];
      $data = $validator->getData();
      $min_value = $data[$min_field];
      return $value > $min_value;
    });   

    Validator::replacer('greater_than_field', function($message, $attribute, $rule, $parameters) {
      return str_replace(':field', $parameters[0], $message);
    });
  }
}

Now you can use your brand new validation rule in your $rules:

$rules = [
  'initial_page' => 'required_with:end_page|integer|min:1|digits_between: 1,5',
  'end_page' => 'required_with:initial_page|integer|greater_than_field:initial_page|digits_between:1,5'
]; 

You'll find more info about creating custom validators here: http://laravel.com/docs/5.1/validation#custom-validation-rules. They are easy to define and can then be used everywhere you validate your data.

like image 80
jedrzej.kurylo Avatar answered Oct 19 '22 03:10

jedrzej.kurylo


the question was asked in 2015 so most of the answers are also outdated now in 2019

i want to give answer which uses features provided by laravel team which is included in it's new version,

so as stated by @Sarpadoruk as of laravel 5.6 laravel added features in validation like gt,gte,lt and lte which means:

  • gt - greater than
  • gte - greater than equal to
  • lt - less than
  • lte - less than equal to

so using gt you can check that your end_page should be greater than your initial_page and your task becomes very easy now:

$rules = [
  'initial_page' => 'required_with:end_page|integer|min:1|digits_between: 1,5',
  'end_page' => 'required_with:initial_page|integer|gt:initial_page|digits_between:1,5'
]; 
like image 60
Haritsinh Gohil Avatar answered Oct 19 '22 02:10

Haritsinh Gohil


For Laravel 5.4 it will be:

$rules = ['end_page'=>'min:'.(int)$request->initial_page]
like image 22
Nagibaba Avatar answered Oct 19 '22 03:10

Nagibaba