32 lines
1.2 KiB
Ruby
32 lines
1.2 KiB
Ruby
namespace :polls do
|
|
desc "Removes duplicate poll voters"
|
|
task remove_duplicate_voters: :environment do
|
|
logger = ApplicationLogger.new
|
|
duplicate_records_logger = DuplicateRecordsLogger.new
|
|
|
|
logger.info "Removing duplicate voters in polls"
|
|
|
|
Tenant.run_on_each do
|
|
duplicate_ids = Poll::Voter.select(:user_id, :poll_id)
|
|
.group(:user_id, :poll_id)
|
|
.having("count(*) > 1")
|
|
.pluck(:user_id, :poll_id)
|
|
|
|
duplicate_ids.each do |user_id, poll_id|
|
|
voters = Poll::Voter.where(user_id: user_id, poll_id: poll_id)
|
|
voters.excluding(voters.first).each do |voter|
|
|
voter.delete
|
|
|
|
tenant_info = " on tenant #{Tenant.current_schema}" unless Tenant.default?
|
|
log_message = "Deleted duplicate record with ID #{voter.id} " \
|
|
"from the #{Poll::Voter.table_name} table " \
|
|
"with user_id #{user_id} " \
|
|
"and poll_id #{poll_id}" + tenant_info.to_s
|
|
logger.info(log_message)
|
|
duplicate_records_logger.info(log_message)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|