One option would be to put it in the controller. You can simply check the dates and create an instance variable containing an error message. That isn’t very DRY though. Want to do it somewhere else? Then you’re duplicating the code.
Another option is to create a dummy model that does not inherit from ActiveRecord, then include the validations there. If you add the right methods, you can interact with it just like a normal AR model. Something like this should get you started:
class MySearchClass
include ActiveModel::Validations
validates :start_date
validates :end_date
def save
return false unless valid?
# the dates were valid, go ahead and query the records
return true
I would not call this 'validation' as that term is normally kept for
checking data being saved in the db. What you are doing here is just
checking that the parameters to the controller action are ok before
accepting the action. In that case I would say it is fine in the
controller to check the dates before allowing the action.
The javascript method is probably arguably even better as it avoids
the round trip to the server. I would probably not bother with the
additional complication however, it is not a regular occurrence
(presumably) and even if you validate in javascript you will still
have to check in the controller in case the user has javascript
disabled.