diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2017-04-04 02:00:10 +0200 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2017-04-04 02:00:10 +0200 |
commit | b510a56c0c3d8c1a48bb295a85b688af94466723 (patch) | |
tree | bdc7f1edf2b8599bc2d94b7752acdcfc217eeae8 /app/models | |
parent | 4c53af64f0b10bc11473df5e3fd1cd7a11b755f6 (diff) |
Only call regeneration worker after first login after a 14 day break
Diffstat (limited to 'app/models')
-rw-r--r-- | app/models/feed.rb | 12 |
1 files changed, 2 insertions, 10 deletions
diff --git a/app/models/feed.rb b/app/models/feed.rb index 5e1905e15..3cbc160a0 100644 --- a/app/models/feed.rb +++ b/app/models/feed.rb @@ -10,17 +10,9 @@ class Feed max_id = '+inf' if max_id.blank? since_id = '-inf' if since_id.blank? unhydrated = redis.zrevrangebyscore(key, "(#{max_id}", "(#{since_id}", limit: [0, limit], with_scores: true).map(&:last).map(&:to_i) + status_map = Status.where(id: unhydrated).cache_ids.map { |s| [s.id, s] }.to_h - # If we're after most recent items and none are there, we need to precompute the feed - if unhydrated.empty? && max_id == '+inf' && since_id == '-inf' - RegenerationWorker.perform_async(@account.id, @type) - @statuses = Status.send("as_#{@type}_timeline", @account).cache_ids.paginate_by_max_id(limit, nil, nil) - else - status_map = Status.where(id: unhydrated).cache_ids.map { |s| [s.id, s] }.to_h - @statuses = unhydrated.map { |id| status_map[id] }.compact - end - - @statuses + unhydrated.map { |id| status_map[id] }.compact end private |