class SchemeEmailCsvJob < ApplicationJob include Rails.application.routes.url_helpers queue_as :default BYTE_ORDER_MARK = "\uFEFF".freeze # Required to ensure Excel always reads CSV as UTF-8 EXPIRATION_TIME = 48.hours.to_i def perform(user, search_term = nil, filters = {}, all_orgs = false, organisation = nil, download_type = "combined") # rubocop:disable Style/OptionalBooleanParameter - sidekiq can't serialise named params unfiltered_schemes = if organisation.present? && user.support? Scheme.where(owning_organisation: [organisation] + organisation.parent_organisations) else user.schemes end filtered_schemes = FilterManager.filter_schemes(unfiltered_schemes, search_term, filters, all_orgs, user) csv_string = Csv::SchemeCsvService.new(download_type:).prepare_csv(filtered_schemes) case download_type when "schemes" filename = "#{['schemes', organisation&.name, Time.zone.now].compact.join('-')}.csv" when "locations" filename = "#{['locations', organisation&.name, Time.zone.now].compact.join('-')}.csv" when "combined" filename = "#{['schemes-and-locations', organisation&.name, Time.zone.now].compact.join('-')}.csv" end storage_service = if FeatureToggle.upload_enabled? Storage::S3Service.new(Configuration::EnvConfigurationService.new, ENV["BULK_UPLOAD_BUCKET"]) else Storage::LocalDiskService.new end storage_service.write_file(filename, BYTE_ORDER_MARK + csv_string) csv_download = CsvDownload.create!(user:, organisation: user.organisation, filename:, download_type:, expiration_time: EXPIRATION_TIME) url = csv_download_url(csv_download.id, host: ENV["APP_HOST"]) CsvDownloadMailer.new.send_csv_download_mail(user, url, EXPIRATION_TIME) end end