2013-02-05 14:16:51 -05:00
|
|
|
class UserVisit < ActiveRecord::Base
|
2013-02-27 22:39:42 -05:00
|
|
|
|
2017-07-27 21:20:09 -04:00
|
|
|
def self.counts_by_day_query(start_date, end_date, group_id = nil)
|
2016-02-02 21:29:51 -05:00
|
|
|
result = where('visited_at >= ? and visited_at <= ?', start_date.to_date, end_date.to_date)
|
|
|
|
|
|
|
|
if group_id
|
|
|
|
result = result.joins("INNER JOIN users ON users.id = user_visits.user_id")
|
|
|
|
result = result.joins("INNER JOIN group_users ON group_users.user_id = users.id")
|
|
|
|
result = result.where("group_users.group_id = ?", group_id)
|
|
|
|
end
|
|
|
|
result.group(:visited_at).order(:visited_at)
|
2015-07-07 12:31:07 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
# A count of visits in a date range by day
|
2017-07-27 21:20:09 -04:00
|
|
|
def self.by_day(start_date, end_date, group_id = nil)
|
2016-02-02 21:29:51 -05:00
|
|
|
counts_by_day_query(start_date, end_date, group_id).count
|
2015-07-07 12:31:07 -04:00
|
|
|
end
|
|
|
|
|
2017-07-27 21:20:09 -04:00
|
|
|
def self.mobile_by_day(start_date, end_date, group_id = nil)
|
2016-02-02 21:29:51 -05:00
|
|
|
counts_by_day_query(start_date, end_date, group_id).where(mobile: true).count
|
2013-02-27 22:39:42 -05:00
|
|
|
end
|
2013-04-05 02:43:48 -04:00
|
|
|
|
|
|
|
def self.ensure_consistency!
|
|
|
|
exec_sql <<SQL
|
2013-10-03 23:28:49 -04:00
|
|
|
UPDATE user_stats u set days_visited =
|
2013-04-05 02:43:48 -04:00
|
|
|
(
|
2013-10-03 23:28:49 -04:00
|
|
|
SELECT COUNT(*) FROM user_visits v WHERE v.user_id = u.user_id
|
2013-04-05 02:43:48 -04:00
|
|
|
)
|
|
|
|
WHERE days_visited <>
|
|
|
|
(
|
2013-10-03 23:28:49 -04:00
|
|
|
SELECT COUNT(*) FROM user_visits v WHERE v.user_id = u.user_id
|
2013-04-05 02:43:48 -04:00
|
|
|
)
|
|
|
|
SQL
|
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
2013-05-23 22:48:32 -04:00
|
|
|
|
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: user_visits
|
|
|
|
#
|
|
|
|
# id :integer not null, primary key
|
|
|
|
# user_id :integer not null
|
|
|
|
# visited_at :date not null
|
2014-02-06 19:07:36 -05:00
|
|
|
# posts_read :integer default(0)
|
2015-07-07 12:31:07 -04:00
|
|
|
# mobile :boolean default(FALSE)
|
2013-05-23 22:48:32 -04:00
|
|
|
#
|
|
|
|
# Indexes
|
|
|
|
#
|
|
|
|
# index_user_visits_on_user_id_and_visited_at (user_id,visited_at) UNIQUE
|
2015-09-17 20:41:10 -04:00
|
|
|
# index_user_visits_on_visited_at_and_mobile (visited_at,mobile)
|
2013-05-23 22:48:32 -04:00
|
|
|
#
|