diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2017-07-23 01:15:04 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-07-23 01:15:04 +0200 |
commit | 7964bfccdb0bc30c4f15db092b66a6f8d57f1262 (patch) | |
tree | 14e62b1f8bf1185b49f26bae49bf2b60dac4382f | |
parent | 3c515f2cd2a636e06c2cdf67d3493671134b6839 (diff) |
Add rake task mastodon:feeds:build to regenerate all active users' feeds (#4303)
-rw-r--r-- | app/models/user.rb | 1 | ||||
-rw-r--r-- | lib/tasks/mastodon.rake | 7 |
2 files changed, 8 insertions, 0 deletions
diff --git a/app/models/user.rb b/app/models/user.rb index 25dc25864..96a2d09b7 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -53,6 +53,7 @@ class User < ApplicationRecord scope :admins, -> { where(admin: true) } scope :confirmed, -> { where.not(confirmed_at: nil) } scope :inactive, -> { where(arel_table[:current_sign_in_at].lt(ACTIVE_DURATION.ago)) } + scope :active, -> { confirmed.where(arel_table[:current_sign_in_at].gteq(ACTIVE_DURATION.ago)).joins(:account).where(accounts: { suspended: false }) } scope :matches_email, ->(value) { where(arel_table[:email].matches("#{value}%")) } scope :with_recent_ip_address, ->(value) { where(arel_table[:current_sign_in_ip].eq(value).or(arel_table[:last_sign_in_ip].eq(value))) } diff --git a/lib/tasks/mastodon.rake b/lib/tasks/mastodon.rake index bceeeaf01..edfa3a4ac 100644 --- a/lib/tasks/mastodon.rake +++ b/lib/tasks/mastodon.rake @@ -143,6 +143,13 @@ namespace :mastodon do task clear_all: :environment do Redis.current.keys('feed:*').each { |key| Redis.current.del(key) } end + + desc 'Generates home timelines for users who logged in in the past two weeks' + task build: :environment do + User.active.includes(:account).find_each do |u| + PrecomputeFeedService.new.call(u.account) + end + end end namespace :emails do |