blob: 9ff3d8d2c91a26728cd8c6f57e6ed2828d27a7ce (
plain)
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
|