Add a log file to track deleted duplicate records
It might be interesting in some cases to check the information related to those records.
This commit is contained in:
21
app/lib/duplicate_records_logger.rb
Normal file
21
app/lib/duplicate_records_logger.rb
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
class DuplicateRecordsLogger
|
||||||
|
def info(message)
|
||||||
|
logger.info(message)
|
||||||
|
end
|
||||||
|
|
||||||
|
def logger
|
||||||
|
@logger ||= ActiveSupport::Logger.new(log_file).tap do |logger|
|
||||||
|
logger.formatter = Rails.application.config.log_formatter
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def log_file
|
||||||
|
File.join(File.dirname(Rails.application.config.default_log_file), log_filename)
|
||||||
|
end
|
||||||
|
|
||||||
|
def log_filename
|
||||||
|
"duplicate_records.log"
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -2,6 +2,8 @@ namespace :polls do
|
|||||||
desc "Removes duplicate poll voters"
|
desc "Removes duplicate poll voters"
|
||||||
task remove_duplicate_voters: :environment do
|
task remove_duplicate_voters: :environment do
|
||||||
logger = ApplicationLogger.new
|
logger = ApplicationLogger.new
|
||||||
|
duplicate_records_logger = DuplicateRecordsLogger.new
|
||||||
|
|
||||||
logger.info "Removing duplicate voters in polls"
|
logger.info "Removing duplicate voters in polls"
|
||||||
|
|
||||||
Tenant.run_on_each do
|
Tenant.run_on_each do
|
||||||
@@ -16,10 +18,12 @@ namespace :polls do
|
|||||||
voter.delete
|
voter.delete
|
||||||
|
|
||||||
tenant_info = " on tenant #{Tenant.current_schema}" unless Tenant.default?
|
tenant_info = " on tenant #{Tenant.current_schema}" unless Tenant.default?
|
||||||
logger.info "Deleted duplicate record with ID #{voter.id} " \
|
log_message = "Deleted duplicate record with ID #{voter.id} " \
|
||||||
"from the #{Poll::Voter.table_name} table " \
|
"from the #{Poll::Voter.table_name} table " \
|
||||||
"with user_id #{user_id} " \
|
"with user_id #{user_id} " \
|
||||||
"and poll_id #{poll_id}" + tenant_info.to_s
|
"and poll_id #{poll_id}" + tenant_info.to_s
|
||||||
|
logger.info(log_message)
|
||||||
|
duplicate_records_logger.info(log_message)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user