スケジュールの start_date と end_date が別のスケジュールと重複していないことを確認するカスタム検証を作成しようとしています
class Schedule < ActiveRecord::Base
#has many scheduleTimes (fk in scheduleTime)
has_many :scheduletimes, :inverse_of => :schedule
validate :dateOverlaps?
scope :active, lambda {
where('? between start_date and end_date', Date.today)
}
def dateOverlaps?
results = ActiveRecord::Base.connection.execute("Select (start_date::DATE, end_date::DATE) OVERLAPS ('#{self.start_date}'::DATE, '#{self.end_date}'::DATE) from schedules;")
errors.add_to_base("Date ranges cannot overlap with another schedule") if results.first["overlaps"] == 't'
end
ただし、これにより
NoMethodError: undefined method `add_to_base'
カスタムバリデータを作成し、プライベート検証メソッドを使用してみましたが、役に立ちませんでした。誰かが私のためにこれに光を当てることができますか?