| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  | # frozen_string_literal: true | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ActivityTracker | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |   include Redisable | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-29 14:31:51 -05:00
										 |  |  |   EXPIRE_AFTER = 6.months.seconds | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |   def initialize(prefix, type) | 
					
						
							|  |  |  |     @prefix = prefix | 
					
						
							|  |  |  |     @type   = type | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2019-02-02 12:11:38 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |   def add(value = 1, at_time = Time.now.utc) | 
					
						
							|  |  |  |     key = key_at(at_time) | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |     case @type | 
					
						
							|  |  |  |     when :basic | 
					
						
							|  |  |  |       redis.incrby(key, value) | 
					
						
							|  |  |  |     when :unique | 
					
						
							|  |  |  |       redis.pfadd(key, value) | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |     redis.expire(key, EXPIRE_AFTER) | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |   def get(start_at, end_at = Time.now.utc) | 
					
						
							|  |  |  |     (start_at.to_date...end_at.to_date).map do |date| | 
					
						
							|  |  |  |       key = key_at(date.to_time(:utc)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       value = begin | 
					
						
							|  |  |  |         case @type | 
					
						
							|  |  |  |         when :basic | 
					
						
							|  |  |  |           redis.get(key).to_i | 
					
						
							|  |  |  |         when :unique | 
					
						
							|  |  |  |           redis.pfcount(key) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       [date, value] | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def sum(start_at, end_at = Time.now.utc) | 
					
						
							|  |  |  |     keys = (start_at.to_date...end_at.to_date).flat_map { |date| [key_at(date.to_time(:utc)), legacy_key_at(date)] }.uniq | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     case @type | 
					
						
							|  |  |  |     when :basic | 
					
						
							|  |  |  |       redis.mget(*keys).map(&:to_i).sum | 
					
						
							|  |  |  |     when :unique | 
					
						
							|  |  |  |       redis.pfcount(*keys) | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |   end | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |   class << self | 
					
						
							|  |  |  |     def increment(prefix) | 
					
						
							|  |  |  |       new(prefix, :basic).add | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  |     def record(prefix, value) | 
					
						
							|  |  |  |       new(prefix, :unique).add(value) | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2021-10-14 13:44:59 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |   private | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def key_at(at_time) | 
					
						
							|  |  |  |     "#{@prefix}:#{at_time.beginning_of_day.to_i}" | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def legacy_key_at(at_time) | 
					
						
							|  |  |  |     "#{@prefix}:#{at_time.to_date.cweek}" | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2017-12-29 12:52:04 -06:00
										 |  |  | end |