module Csv class MissingAddressesCsvService def initialize(organisation, skip_uprn_issue_organisations) @organisation = organisation @skip_uprn_issue_organisations = skip_uprn_issue_organisations end def create_missing_lettings_addresses_csv logs_with_missing_addresses = @organisation.managed_lettings_logs .imported_2023_with_old_form_id .where(needstype: 1, address_line1: nil, town_or_city: nil, uprn_known: [0, nil]) logs_with_missing_town_or_city = @organisation.managed_lettings_logs .imported_2023_with_old_form_id .where(needstype: 1, town_or_city: nil, uprn_known: [0, nil]) .where.not(address_line1: nil) logs_with_wrong_uprn = if @skip_uprn_issue_organisations.include?(@organisation.id) [] else @organisation.managed_lettings_logs .imported_2023 .where(needstype: 1) .where.not(uprn: nil) .where("uprn = propcode OR uprn = tenancycode OR town_or_city = 'Bristol'") end return if logs_with_missing_addresses.empty? && logs_with_missing_town_or_city.empty? && logs_with_wrong_uprn.empty? CSV.generate(headers: true) do |csv| csv << ["Issue type", "Log ID", "Tenancy start date", "Tenant code", "Property reference", "Log owner", "Owning organisation", "Managing organisation", "UPRN", "Address Line 1", "Address Line 2 (optional)", "Town or City", "County (optional)", "Property's postcode"] logs_with_missing_addresses.each do |log| csv << ["Full address required"] + lettings_log_to_csv_row(log) end logs_with_missing_town_or_city.each do |log| csv << ["Missing town or city"] + lettings_log_to_csv_row(log) end logs_with_wrong_uprn.each do |log| csv << ["Incorrect UPRN"] + lettings_log_to_csv_row(log) end end end def create_missing_sales_addresses_csv logs_with_missing_addresses = @organisation.sales_logs .imported_2023_with_old_form_id .where(address_line1: nil, town_or_city: nil, uprn_known: [0, nil]) logs_with_missing_town_or_city = @organisation.sales_logs .imported_2023_with_old_form_id .where(town_or_city: nil, uprn_known: [0, nil]) .where.not(address_line1: nil) logs_with_wrong_uprn = if @skip_uprn_issue_organisations.include?(@organisation.id) [] else @organisation.sales_logs .imported_2023 .where.not(uprn: nil) .where("uprn = purchid OR town_or_city = 'Bristol'") end return if logs_with_missing_addresses.empty? && logs_with_missing_town_or_city.empty? && logs_with_wrong_uprn.empty? CSV.generate(headers: true) do |csv| csv << ["Issue type", "Log ID", "Sale completion date", "Purchaser code", "Log owner", "Owning organisation", "UPRN", "Address Line 1", "Address Line 2 (optional)", "Town or City", "County (optional)", "Property's postcode"] logs_with_missing_addresses.each do |log| csv << ["Full address required"] + sales_log_to_csv_row(log) end logs_with_missing_town_or_city.each do |log| csv << ["Missing town or city"] + sales_log_to_csv_row(log) end logs_with_wrong_uprn.each do |log| csv << ["Incorrect UPRN"] + sales_log_to_csv_row(log) end end end def create_lettings_addresses_csv logs = @organisation.managed_lettings_logs.filter_by_year(2023) CSV.generate(headers: true) do |csv| csv << ["Log ID", "Tenancy start date", "Tenant code", "Property reference", "Log owner", "Owning organisation", "Managing organisation", "UPRN", "Address Line 1", "Address Line 2 (optional)", "Town or City", "County (optional)", "Property's postcode"] logs.each do |log| csv << lettings_log_to_csv_row(log) end end end def create_sales_addresses_csv logs = @organisation.sales_logs.filter_by_year(2023) CSV.generate(headers: true) do |csv| csv << ["Log ID", "Sale completion date", "Purchaser code", "Log owner", "Owning organisation", "UPRN", "Address Line 1", "Address Line 2 (optional)", "Town or City", "County (optional)", "Property's postcode"] logs.each do |log| csv << sales_log_to_csv_row(log) end end end private def sales_log_to_csv_row(log) [log.id, log.saledate&.to_date, log.purchid, log.created_by&.email, log.owning_organisation&.name, log.uprn, log.address_line1, log.address_line2, log.town_or_city, log.county, log.postcode_full] end def lettings_log_to_csv_row(log) [log.id, log.startdate&.to_date, log.tenancycode, log.propcode, log.created_by&.email, log.owning_organisation&.name, log.managing_organisation&.name, log.uprn, log.address_line1, log.address_line2, log.town_or_city, log.county, log.postcode_full] end end end