diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2017-05-20 19:42:58 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-05-20 19:42:58 +0200 |
commit | ef900789bc99d3bb3cad3b664c7dd5b9bcd1a20c (patch) | |
tree | 5ad8886d984cf66c5c8f3bfa9c3bf2fea74a0f50 /app/workers/scheduler | |
parent | d78f5552547b5175770dbfbefeff73e426da980d (diff) |
Replace mastodon:media:clear and mastodon:feeds:clear rake tasks with (#3180)
sidekiq-scheduler jobs Resolves #2495
Diffstat (limited to 'app/workers/scheduler')
-rw-r--r-- | app/workers/scheduler/feed_cleanup_scheduler.rb | 26 | ||||
-rw-r--r-- | app/workers/scheduler/media_cleanup_scheduler.rb | 17 |
2 files changed, 43 insertions, 0 deletions
diff --git a/app/workers/scheduler/feed_cleanup_scheduler.rb b/app/workers/scheduler/feed_cleanup_scheduler.rb new file mode 100644 index 000000000..c7df363a4 --- /dev/null +++ b/app/workers/scheduler/feed_cleanup_scheduler.rb @@ -0,0 +1,26 @@ +# frozen_string_literal: true +require 'sidekiq-scheduler' + +class Scheduler::FeedCleanupScheduler + include Sidekiq::Worker + + def perform + logger.info 'Cleaning out home feeds of inactive users' + + redis.pipelined do + inactive_users.pluck(:account_id).each do |account_id| + redis.del(FeedManager.instance.key(:home, account_id)) + end + end + end + + private + + def inactive_users + User.confirmed.where('current_sign_in_at < ?', 14.days.ago) + end + + def redis + Redis.current + end +end diff --git a/app/workers/scheduler/media_cleanup_scheduler.rb b/app/workers/scheduler/media_cleanup_scheduler.rb new file mode 100644 index 000000000..885ee9afc --- /dev/null +++ b/app/workers/scheduler/media_cleanup_scheduler.rb @@ -0,0 +1,17 @@ +# frozen_string_literal: true +require 'sidekiq-scheduler' + +class Scheduler::MediaCleanupScheduler + include Sidekiq::Worker + + def perform + logger.info 'Cleaning out unattached media attachments' + unattached_media.find_each(&:destroy) + end + + private + + def unattached_media + MediaAttachment.reorder(nil).where(status_id: nil).where('created_at < ?', 1.day.ago) + end +end |