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.
140 lines
5.3 KiB
140 lines
5.3 KiB
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
|
|
|