From 2ee6a21d2fe69e8d28319a97a5c48df9250696f0 Mon Sep 17 00:00:00 2001 From: Marcus Aspin Date: Fri, 1 Nov 2024 11:29:08 +0000 Subject: [PATCH] PI-2543 Simplify outcome and duplicate mobile number check --- .../repository/UpwAppointmentRepository.kt | 69 +++++++++---------- 1 file changed, 33 insertions(+), 36 deletions(-) diff --git a/projects/appointment-reminders-and-delius/src/main/kotlin/uk/gov/justice/digital/hmpps/repository/UpwAppointmentRepository.kt b/projects/appointment-reminders-and-delius/src/main/kotlin/uk/gov/justice/digital/hmpps/repository/UpwAppointmentRepository.kt index 041b290036..b4222f0bf6 100644 --- a/projects/appointment-reminders-and-delius/src/main/kotlin/uk/gov/justice/digital/hmpps/repository/UpwAppointmentRepository.kt +++ b/projects/appointment-reminders-and-delius/src/main/kotlin/uk/gov/justice/digital/hmpps/repository/UpwAppointmentRepository.kt @@ -11,42 +11,62 @@ interface UpwAppointmentRepository : JpaRepository { """ select any_value(first_name) as "firstName", - any_value(mobile_number) as "mobileNumber", + any_value(formatted_mobile_number) as "mobileNumber", any_value(to_char(appointment_date, 'DD/MM/YYYY')) as "appointmentDate", -- for testing -- crn as "crn", listagg(distinct event_number, ', ') as "eventNumbers", listagg(distinct upw_appointment_id, ', ') as "upwAppointmentIds" from ( + with unique_mobile_numbers as ( + select + replace(mobile_number, ' ', '') as formatted_mobile_number, + any_value(offender_id) as offender_id + from offender where soft_deleted = 0 + -- no other cases with the same mobile number + group by replace(mobile_number, ' ', '') having count(*) = 1) select first_name, - replace(mobile_number, ' ', '') as mobile_number, + formatted_mobile_number, upw_appointment.appointment_date as appointment_date, crn, event_number, upw_appointment.upw_appointment_id - from offender + from unique_mobile_numbers + join offender on offender.offender_id = unique_mobile_numbers.offender_id join event on event.offender_id = offender.offender_id and event.active_flag = 1 and event.soft_deleted = 0 join disposal on disposal.event_id = event.event_id and disposal.active_flag = 1 and disposal.soft_deleted = 0 join r_disposal_type on r_disposal_type.disposal_type_id = disposal.disposal_type_id join upw_details on upw_details.disposal_id = disposal.disposal_id and upw_details.soft_deleted = 0 join upw_appointment on upw_appointment.upw_details_id = upw_details.upw_details_id and upw_appointment.soft_deleted = 0 and trunc(upw_appointment.appointment_date) = :date - left join r_contact_outcome_type on r_contact_outcome_type.contact_outcome_type_id = upw_appointment.contact_outcome_type_id join upw_project on upw_project.upw_project_id = upw_appointment.upw_project_id join r_standard_reference_list upw_project_type on upw_project_type.standard_reference_list_id = upw_project.project_type_id and upw_project_type.code_value in ('ES','ICP','NP1','NP2','PI','PIP','PIP2','PL','PS','PSP','WH1') join probation_area on probation_area.probation_area_id = upw_project.probation_area_id and probation_area.code = :providerCode left join exclusion on exclusion.offender_id = offender.offender_id and exclusion_date < current_date and (exclusion_end_date is null or current_date < exclusion_end_date) left join restriction on restriction.offender_id = offender.offender_id and restriction_date < current_date and (restriction_end_date is null or current_date < restriction_end_date) - where offender.soft_deleted = 0 - -- valid mobile number and sms allowed - and replace(mobile_number, ' ', '') like '07%' - and length(replace(mobile_number, ' ', '')) = 11 - and validate_conversion(replace(mobile_number, ' ', '') as number) = 1 + -- valid mobile number + where formatted_mobile_number like '07%' and length(formatted_mobile_number) = 11 and validate_conversion(formatted_mobile_number as number) = 1 + -- sms is allowed and (allow_sms is null or allow_sms = 'Y') - -- no other cases with the same mobile number - and not exists ( - select 1 from offender duplicate where duplicate.soft_deleted = 0 and replace(duplicate.mobile_number, ' ', '') = replace(offender.mobile_number, ' ', '') and duplicate.offender_id <> offender.offender_id - ) + -- no access limitations + and restriction_id is null and exclusion_id is null + -- appointment does not have an outcome + and upw_appointment.contact_outcome_type_id is null + -- not on remand + and (current_remand_status is null or (current_remand_status not in ('Warrant With Bail', 'Warrant Without Bail', 'Remanded In Custody', 'Unlawfully at Large') and current_remand_status not like 'UAL%')) + and not exists (select 1 from personal_circumstance + join r_circumstance_type on r_circumstance_type.circumstance_type_id = personal_circumstance.circumstance_type_id and r_circumstance_type.code_value = 'RIC' + where personal_circumstance.offender_id = offender.offender_id and personal_circumstance.soft_deleted = 0 and (personal_circumstance.end_date is null or personal_circumstance.end_date > current_date)) + -- not in custody + and not exists (select 1 from custody + join disposal custody_disposal on custody_disposal.disposal_id = custody.disposal_id and custody_disposal.active_flag = 1 and custody_disposal.soft_deleted = 0 + join event custody_event on custody_event.event_id = custody_disposal.event_id and custody_event.offender_id = offender.offender_id and custody_event.active_flag = 1 and custody_event.soft_deleted = 0 + join r_standard_reference_list custodial_status on custodial_status.standard_reference_list_id = custody.custodial_status_id and custodial_status.code_value in ('A', 'C', 'D') + where custody.soft_deleted = 0) + -- not on warrant or unlawfully at large + and not exists (select 1 from registration + join r_register_type on r_register_type.register_type_id = registration.register_type_id and r_register_type.code in ('IWWO', 'IWWB', 'WRSM', 'HUAL') + where registration.offender_id = offender.offender_id and registration.deregistered = 0 and registration.soft_deleted = 0) -- has an active unpaid work requirement and exists (select 1 from rqmnt join r_rqmnt_type_main_category on r_rqmnt_type_main_category.rqmnt_type_main_category_id = rqmnt.rqmnt_type_main_category_id and r_rqmnt_type_main_category.code in ('W', 'W0', 'W1', 'W2') @@ -67,29 +87,6 @@ interface UpwAppointmentRepository : JpaRepository { (select coalesce(sum(appts.minutes_credited), 0) from upw_appointment appts where appts.upw_details_id = upw_details.upw_details_id and appts.soft_deleted = 0) as minutes_credited from dual)) > 0 - -- appointment does not have an outcome - and r_contact_outcome_type.description is null - -- not in custody - and not exists (select 1 from custody - join disposal custody_disposal on custody_disposal.disposal_id = custody.disposal_id and custody_disposal.active_flag = 1 and custody_disposal.soft_deleted = 0 - join event custody_event on custody_event.event_id = custody_disposal.event_id and custody_event.offender_id = offender.offender_id and custody_event.active_flag = 1 and custody_event.soft_deleted = 0 - join r_standard_reference_list custodial_status on custodial_status.standard_reference_list_id = custody.custodial_status_id and custodial_status.code_value in ('A', 'C', 'D') - where custody.soft_deleted = 0) - -- not on remand - and (current_remand_status is null or (current_remand_status not in ('Warrant With Bail', 'Warrant Without Bail', 'Remanded In Custody', 'Unlawfully at Large') and current_remand_status not like 'UAL%')) - and not exists (select 1 from personal_circumstance - join r_circumstance_type on r_circumstance_type.circumstance_type_id = personal_circumstance.circumstance_type_id and r_circumstance_type.code_value = 'RIC' - where personal_circumstance.offender_id = offender.offender_id and personal_circumstance.soft_deleted = 0 and (personal_circumstance.end_date is null or personal_circumstance.end_date > current_date)) - -- not unlawfully at large - and not exists (select 1 from registration - join r_register_type on r_register_type.register_type_id = registration.register_type_id and r_register_type.code in ('HUAL') - where registration.offender_id = offender.offender_id and registration.deregistered = 0 and registration.soft_deleted = 0) - -- not on warrant - and not exists (select 1 from registration - join r_register_type on r_register_type.register_type_id = registration.register_type_id and r_register_type.code in ('IWWO', 'IWWB', 'WRSM') - where registration.offender_id = offender.offender_id and registration.deregistered = 0 and registration.soft_deleted = 0) - -- no access limitations - and restriction_id is null and exclusion_id is null ) group by crn order by crn