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.
This commit is contained in:
parent
4ec9d8b4d9
commit
1cc44cba81
2 changed files with 22 additions and 19 deletions
|
@ -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
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue