# frozen_string_literal: true # == Schema Information # # Table name: terms_of_services # # id :bigint(8) not null, primary key # changelog :text default(""), not null # effective_date :date # notification_sent_at :datetime # published_at :datetime # text :text default(""), not null # created_at :datetime not null # updated_at :datetime not null # class TermsOfService < ApplicationRecord scope :published, -> { where.not(published_at: nil).order(Arel.sql('coalesce(effective_date, published_at) DESC')) } scope :live, -> { published.where('effective_date IS NULL OR effective_date < now()').limit(1) } scope :draft, -> { where(published_at: nil).order(id: :desc).limit(1) } validates :text, presence: true validates :changelog, :effective_date, presence: true, if: -> { published? } validate :effective_date_cannot_be_in_the_past def published? published_at.present? end def effective? published? && effective_date&.past? end def succeeded_by TermsOfService.published.where(effective_date: (effective_date..)).where.not(id: id).first end def notification_sent? notification_sent_at.present? end def scope_for_notification User.confirmed.joins(:account).merge(Account.without_suspended).where(created_at: (..published_at)) end private def effective_date_cannot_be_in_the_past return if effective_date.blank? min_date = TermsOfService.live.pick(:effective_date) || Time.zone.today errors.add(:effective_date, :too_soon, date: min_date) if effective_date < min_date end end