12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- # frozen_string_literal: true
- # == Schema Information
- #
- # Table name: instances
- #
- # domain :string primary key
- # accounts_count :bigint(8)
- #
- class Instance < ApplicationRecord
- self.primary_key = :domain
- attr_accessor :failure_days
- has_many :accounts, foreign_key: :domain, primary_key: :domain
- belongs_to :domain_block, foreign_key: :domain, primary_key: :domain
- belongs_to :domain_allow, foreign_key: :domain, primary_key: :domain
- belongs_to :unavailable_domain, foreign_key: :domain, primary_key: :domain # skipcq: RB-RL1031
- scope :matches_domain, ->(value) { where(arel_table[:domain].matches("%#{value}%")) }
- def self.refresh
- Scenic.database.refresh_materialized_view(table_name, concurrently: true, cascade: false)
- end
- def readonly?
- true
- end
- def delivery_failure_tracker
- @delivery_failure_tracker ||= DeliveryFailureTracker.new(domain)
- end
- def purgeable?
- unavailable? || domain_block&.suspend?
- end
- def unavailable?
- unavailable_domain.present?
- end
- def failing?
- failure_days.present? || unavailable?
- end
- def to_param
- domain
- end
- alias to_log_human_identifier to_param
- delegate :exhausted_deliveries_days, to: :delivery_failure_tracker
- def availability_over_days(num_days, end_date = Time.now.utc.to_date)
- failures_map = exhausted_deliveries_days.index_with { true }
- period_end_at = exhausted_deliveries_days.last || end_date
- period_start_at = period_end_at - num_days.days
- (period_start_at..period_end_at).map do |date|
- [date, failures_map[date]]
- end
- end
- end
|