# frozen_string_literal: true class UserCustomAttribute < ApplicationRecord belongs_to :user validates :user_id, :key, :value, presence: true validates :key, uniqueness: { scope: [:user_id] } scope :by_key, ->(key) { where(key: key) } scope :by_user_id, ->(user_id) { where(user_id: user_id) } scope :by_updated_at, ->(updated_at) { where(updated_at: updated_at) } scope :arkose_sessions, -> { by_key('arkose_session') } class << self def upsert_custom_attributes(custom_attributes) created_at = DateTime.now updated_at = DateTime.now custom_attributes.map! do |custom_attribute| custom_attribute.merge({ created_at: created_at, updated_at: updated_at }) end upsert_all(custom_attributes, unique_by: [:user_id, :key]) end def sessions return none if blocked_users.empty? arkose_sessions .by_user_id(blocked_users.map(&:user_id)) .select(:value) end private def blocked_users by_key('blocked_at').by_updated_at(Date.yesterday.all_day) end end end