2017-09-14 22:26:38 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class Scheduler::IpCleanupScheduler
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
2022-07-07 03:14:28 +02:00
|
|
|
IP_RETENTION_PERIOD = ENV.fetch('IP_RETENTION_PERIOD', 1.year).to_i.seconds.freeze
|
|
|
|
SESSION_RETENTION_PERIOD = ENV.fetch('SESSION_RETENTION_PERIOD', 1.year).to_i.seconds.freeze
|
2018-04-04 21:47:39 +02:00
|
|
|
|
2023-08-03 11:04:05 +02:00
|
|
|
sidekiq_options retry: 0, lock: :until_executed, lock_ttl: 1.day.to_i
|
2018-08-19 15:48:29 +02:00
|
|
|
|
2017-09-14 22:26:38 +02:00
|
|
|
def perform
|
2020-10-12 16:33:49 +02:00
|
|
|
clean_ip_columns!
|
|
|
|
clean_expired_ip_blocks!
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def clean_ip_columns!
|
2024-05-20 11:37:36 +02:00
|
|
|
SessionActivation.where(updated_at: ...SESSION_RETENTION_PERIOD.ago).in_batches.destroy_all
|
|
|
|
SessionActivation.where(updated_at: ...IP_RETENTION_PERIOD.ago).in_batches.update_all(ip: nil)
|
|
|
|
User.where(current_sign_in_at: ...IP_RETENTION_PERIOD.ago).in_batches.update_all(sign_up_ip: nil)
|
|
|
|
LoginActivity.where(created_at: ...IP_RETENTION_PERIOD.ago).in_batches.destroy_all
|
|
|
|
Doorkeeper::AccessToken.where(last_used_at: ...IP_RETENTION_PERIOD.ago).in_batches.update_all(last_used_ip: nil)
|
2020-10-12 16:33:49 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def clean_expired_ip_blocks!
|
|
|
|
IpBlock.expired.in_batches.destroy_all
|
2017-09-14 22:26:38 +02:00
|
|
|
end
|
|
|
|
end
|