1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
|
# frozen_string_literal: true
module Users
class ProjectVisit < ApplicationRecord
include Users::Visitable
include PartitionedTable
self.table_name = "projects_visits"
self.primary_key = :id
partitioned_by :visited_at, strategy: :monthly, retain_for: 3.months
validates :entity_id, presence: true
validates :user_id, presence: true
validates :visited_at, presence: true
MAX_FRECENT_ITEMS = 5
def self.frecent_projects(user_id:)
ids = frecent_visits_scores(user_id: user_id, limit: MAX_FRECENT_ITEMS).pluck("entity_id")
Project.find(ids)
end
end
end
|