37 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
# == Schema Information
 | 
						|
#
 | 
						|
# Table name: notification_policies
 | 
						|
#
 | 
						|
#  id                      :bigint(8)        not null, primary key
 | 
						|
#  account_id              :bigint(8)        not null
 | 
						|
#  filter_not_following    :boolean          default(FALSE), not null
 | 
						|
#  filter_not_followers    :boolean          default(FALSE), not null
 | 
						|
#  filter_new_accounts     :boolean          default(FALSE), not null
 | 
						|
#  filter_private_mentions :boolean          default(TRUE), not null
 | 
						|
#  created_at              :datetime         not null
 | 
						|
#  updated_at              :datetime         not null
 | 
						|
#
 | 
						|
 | 
						|
class NotificationPolicy < ApplicationRecord
 | 
						|
  belongs_to :account
 | 
						|
 | 
						|
  has_many :notification_requests, primary_key: :account_id, foreign_key: :account_id, dependent: nil, inverse_of: false
 | 
						|
 | 
						|
  attr_reader :pending_requests_count, :pending_notifications_count
 | 
						|
 | 
						|
  MAX_MEANINGFUL_COUNT = 100
 | 
						|
 | 
						|
  def summarize!
 | 
						|
    @pending_requests_count = pending_notification_requests.first
 | 
						|
    @pending_notifications_count = pending_notification_requests.last
 | 
						|
  end
 | 
						|
 | 
						|
  private
 | 
						|
 | 
						|
  def pending_notification_requests
 | 
						|
    @pending_notification_requests ||= notification_requests.where(dismissed: false).limit(MAX_MEANINGFUL_COUNT).pick(Arel.sql('count(*), coalesce(sum(notifications_count), 0)::bigint'))
 | 
						|
  end
 | 
						|
end
 |