This repository has been archived on 2024-07-22. You can view files and clone it, but cannot push or open issues or pull requests.
2017-09-14 13:26:38 -07:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class Scheduler::IpCleanupScheduler
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
2020-10-12 07:33:49 -07:00
|
|
|
IP_RETENTION_PERIOD = 1.year.freeze
|
2018-04-04 12:47:39 -07:00
|
|
|
|
2021-03-15 03:17:43 -07:00
|
|
|
sidekiq_options retry: 0
|
2018-08-19 06:48:29 -07:00
|
|
|
|
2017-09-14 13:26:38 -07:00
|
|
|
def perform
|
2020-10-12 07:33:49 -07:00
|
|
|
clean_ip_columns!
|
|
|
|
clean_expired_ip_blocks!
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def clean_ip_columns!
|
|
|
|
SessionActivation.where('updated_at < ?', IP_RETENTION_PERIOD.ago).in_batches.destroy_all
|
2022-01-16 04:23:50 -08:00
|
|
|
User.where('current_sign_in_at < ?', IP_RETENTION_PERIOD.ago).in_batches.update_all(sign_up_ip: nil)
|
2021-06-21 08:07:30 -07:00
|
|
|
LoginActivity.where('created_at < ?', IP_RETENTION_PERIOD.ago).in_batches.destroy_all
|
2022-03-01 07:48:58 -08:00
|
|
|
Doorkeeper::AccessToken.where('last_used_at < ?', IP_RETENTION_PERIOD.ago).in_batches.update_all(last_used_ip: nil)
|
2020-10-12 07:33:49 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
def clean_expired_ip_blocks!
|
|
|
|
IpBlock.expired.in_batches.destroy_all
|
2017-09-14 13:26:38 -07:00
|
|
|
end
|
|
|
|
end
|