diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2018-01-23 20:52:30 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-01-23 20:52:30 +0100 |
commit | 1cc44cba81ee7e020f4db58e6b1e6821f47a9641 (patch) | |
tree | 278238b8c2737c2fd2f7f355af7172c49ad44c56 /app/models | |
parent | 4ec9d8b4d9b58766b7356d3173e9cdebf2dbae15 (diff) |
Fix #6331 (#6341)
UserTrackingConcern is circumvented by SessionsController#create because it calls warden, which calls the User#update_tracked_fields! method directly. Move returning user logic to that method.
Diffstat (limited to 'app/models')
-rw-r--r-- | app/models/user.rb | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/app/models/user.rb b/app/models/user.rb index f6a533f84..40c298b1a 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -129,7 +129,7 @@ class User < ApplicationRecord new_user = !confirmed? super - update_statistics! if new_user + prepare_new_user! if new_user end def confirm! @@ -137,7 +137,12 @@ class User < ApplicationRecord skip_confirmation! save! - update_statistics! if new_user + prepare_new_user! if new_user + end + + def update_tracked_fields!(request) + super + prepare_returning_user! end def promote! @@ -220,9 +225,23 @@ class User < ApplicationRecord filtered_languages.reject!(&:blank?) end - def update_statistics! + def prepare_new_user! BootstrapTimelineWorker.perform_async(account_id) ActivityTracker.increment('activity:accounts:local') UserMailer.welcome(self).deliver_later end + + def prepare_returning_user! + ActivityTracker.record('activity:logins', id) + regenerate_feed! if needs_feed_update? + end + + def regenerate_feed! + Redis.current.setnx("account:#{account_id}:regeneration", true) && Redis.current.expire("account:#{account_id}:regeneration", 1.day.seconds) + RegenerationWorker.perform_async(account_id) + end + + def needs_feed_update? + last_sign_in_at < ACTIVE_DURATION.ago + end end |