You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
169 lines
5.5 KiB
169 lines
5.5 KiB
class BulkUploadMailer < NotifyMailer |
|
include ActionView::Helpers::TextHelper |
|
|
|
BULK_UPLOAD_COMPLETE_TEMPLATE_ID = "83279578-c890-4168-838b-33c9cf0dc9f0".freeze |
|
BULK_UPLOAD_FAILED_CSV_ERRORS_TEMPLATE_ID = "e27abcd4-5295-48c2-b127-e9ee4b781b75".freeze |
|
BULK_UPLOAD_FAILED_FILE_SETUP_ERROR_TEMPLATE_ID = "24c9f4c7-96ad-470a-ba31-eb51b7cbafd9".freeze |
|
BULK_UPLOAD_FAILED_SERVICE_ERROR_TEMPLATE_ID = "c3f6288c-7a74-4e77-99ee-6c4a0f6e125a".freeze |
|
BULK_UPLOAD_WITH_ERRORS_TEMPLATE_ID = "eb539005-6234-404e-812d-167728cf4274".freeze |
|
|
|
def send_bulk_upload_complete_mail(user:, bulk_upload:) |
|
url = if bulk_upload.lettings? |
|
lettings_logs_url |
|
else |
|
sales_logs_url |
|
end |
|
|
|
n_logs = pluralize(bulk_upload.logs.count, "log") |
|
|
|
title = "You’ve successfully uploaded #{n_logs}" |
|
|
|
success_description = "The #{bulk_upload.log_type} #{bulk_upload.year_combo} data you uploaded has been checked. The #{n_logs} you uploaded are now complete." |
|
|
|
send_email( |
|
user.email, |
|
BULK_UPLOAD_COMPLETE_TEMPLATE_ID, |
|
{ |
|
title:, |
|
filename: bulk_upload.filename, |
|
upload_timestamp: bulk_upload.created_at, |
|
success_description:, |
|
logs_link: url, |
|
}, |
|
) |
|
end |
|
|
|
def columns_with_errors(bulk_upload:) |
|
array = bulk_upload.columns_with_errors |
|
|
|
if array.size > 3 |
|
"#{array.take(3).join(', ')} and more" |
|
else |
|
array.join(", ") |
|
end |
|
end |
|
|
|
def send_correct_and_upload_again_mail(bulk_upload:, errors:) |
|
any_setup_sections_incomplete_error_description = "logs where the setup sections were incomplete" |
|
over_column_error_threshold_error_description = "logs with a lot of similar errors in column #{columns_with_errors(bulk_upload:)}" |
|
any_logs_already_exist_error_description = "logs you are trying to upload have been created previously" |
|
|
|
errors_list = [] |
|
|
|
errors_list << if errors.size.zero? |
|
"Please correct your data export and upload again." |
|
else |
|
"We noticed the following issues with your upload:" |
|
end |
|
|
|
errors |
|
.select { |_k, v| v } |
|
.each_key do |k| |
|
local_var = "#{k}_error_description" |
|
errors_list << "- #{binding.local_variable_get(local_var)}" |
|
end |
|
|
|
errors_list << "" |
|
|
|
error_description = errors_list.join("\n") |
|
|
|
summary_report_link = if BulkUploadErrorSummaryTableComponent.new(bulk_upload:).errors? |
|
summary_bulk_upload_lettings_result_url(bulk_upload) |
|
else |
|
bulk_upload_lettings_result_url(bulk_upload) |
|
end |
|
|
|
send_email( |
|
bulk_upload.user.email, |
|
BULK_UPLOAD_FAILED_CSV_ERRORS_TEMPLATE_ID, |
|
{ |
|
filename: bulk_upload.filename, |
|
upload_timestamp: bulk_upload.created_at.to_fs(:govuk_date_and_time), |
|
year_combo: bulk_upload.year_combo, |
|
lettings_or_sales: bulk_upload.log_type, |
|
error_description:, |
|
summary_report_link:, |
|
}, |
|
) |
|
end |
|
|
|
def send_bulk_upload_failed_file_setup_error_mail(bulk_upload:) |
|
bulk_upload_link = if bulk_upload.lettings? |
|
start_bulk_upload_lettings_logs_url |
|
else |
|
start_bulk_upload_sales_logs_url |
|
end |
|
|
|
validator_class = if bulk_upload.lettings? |
|
BulkUpload::Lettings::Validator |
|
else |
|
BulkUpload::Sales::Validator |
|
end |
|
|
|
errors = bulk_upload |
|
.bulk_upload_errors |
|
.where(category: "setup") |
|
.group(:col, :field) |
|
.count |
|
.keys |
|
.sort_by { |_col, field| field } |
|
.map do |col, field| |
|
"- Column #{col} (#{validator_class.question_for_field(field.to_sym)})" |
|
end |
|
|
|
send_email( |
|
bulk_upload.user.email, |
|
BULK_UPLOAD_FAILED_FILE_SETUP_ERROR_TEMPLATE_ID, |
|
{ |
|
filename: bulk_upload.filename, |
|
upload_timestamp: bulk_upload.created_at.to_fs(:govuk_date_and_time), |
|
lettings_or_sales: bulk_upload.log_type, |
|
year_combo: bulk_upload.year_combo, |
|
errors_list: errors.join("\n"), |
|
bulk_upload_link:, |
|
}, |
|
) |
|
end |
|
|
|
def send_bulk_upload_failed_service_error_mail(bulk_upload:) |
|
bulk_upload_link = if bulk_upload.lettings? |
|
start_bulk_upload_lettings_logs_url |
|
else |
|
start_bulk_upload_sales_logs_url |
|
end |
|
|
|
send_email( |
|
bulk_upload.user.email, |
|
BULK_UPLOAD_FAILED_SERVICE_ERROR_TEMPLATE_ID, |
|
{ |
|
filename: bulk_upload.filename, |
|
upload_timestamp: bulk_upload.created_at, |
|
lettings_or_sales: bulk_upload.log_type, |
|
year_combo: bulk_upload.year_combo, |
|
bulk_upload_link:, |
|
}, |
|
) |
|
end |
|
|
|
def send_bulk_upload_with_errors_mail(bulk_upload:) |
|
count = bulk_upload.logs.where.not(status: %w[completed]).count |
|
|
|
n_logs = pluralize(count, "log") |
|
|
|
title = "We found #{n_logs} with errors" |
|
|
|
error_description = "We created logs from your #{bulk_upload.year_combo} #{bulk_upload.log_type} data. There was a problem with #{count} of the logs. Click the below link to fix these logs." |
|
|
|
send_email( |
|
bulk_upload.user.email, |
|
BULK_UPLOAD_WITH_ERRORS_TEMPLATE_ID, |
|
{ |
|
title:, |
|
filename: bulk_upload.filename, |
|
upload_timestamp: bulk_upload.created_at.to_fs(:govuk_date_and_time), |
|
error_description:, |
|
summary_report_link: resume_bulk_upload_lettings_result_url(bulk_upload), |
|
}, |
|
) |
|
end |
|
end
|
|
|