Skip to content

Commit

Permalink
Add task if provider / claimant details match
Browse files Browse the repository at this point in the history
If the claimant and provider have matching details (name or email) we
want to raise an admin task for ops to check that the claimant isn't
trying to approve their own claim.
  • Loading branch information
rjlynch committed Sep 26, 2024
1 parent 3894160 commit 7eeff75
Show file tree
Hide file tree
Showing 10 changed files with 215 additions and 2 deletions.
1 change: 1 addition & 0 deletions app/models/claim_checking_tasks.rb
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ def applicable_task_names
task_names.delete("subject")
task_names.delete("teaching_hours")
task_names.delete("provider_verification")
task_names.delete("provider_details")
end
end
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,15 @@ def student_loan_plan
]
end

def provider_details
[
["Provider name", claim.eligibility.provider_full_name],
["Provider email", claim.eligibility.provider_email],
["Claimant name", claim.full_name],
["Claimant email", claim.email_address]
]
end

private

def verifier
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ def applicable_task_names

tasks << "identity_confirmation"
tasks << "provider_verification"
tasks << "provider_details" if claim.eligibility.provider_and_claimant_details_match?
tasks << "employment" if claim.eligibility.teacher_reference_number.present?
tasks << "student_loan_plan" if claim.submitted_without_slc_data?
tasks << "payroll_details" if claim.must_manually_validate_bank_details?
Expand Down
35 changes: 35 additions & 0 deletions app/models/policies/further_education_payments/eligibility.rb
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,41 @@ def permanent_contract?
def verified?
verification.present?
end

def provider_and_claimant_details_match?
provider_and_claimant_names_match? || provider_and_claimant_emails_match?
end

def provider_full_name
"#{provider_first_name} #{provider_last_name}"
end

def provider_email
verification.dig("verifier", "email")
end

private

def provider_and_claimant_names_match?
return false unless verified?

provider_first_name&.downcase == claim.first_name.downcase &&
provider_last_name&.downcase == claim.surname.downcase
end

def provider_and_claimant_emails_match?
return false unless verified?

provider_email&.downcase == claim.email_address.downcase
end

def provider_first_name
verification.dig("verifier", "first_name")
end

def provider_last_name
verification.dig("verifier", "last_name")
end
end
end
end
1 change: 1 addition & 0 deletions app/models/task.rb
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ class Task < ApplicationRecord
previous_payment
identity_confirmation
provider_verification
provider_details
visa
arrival_date
previous_residency
Expand Down
27 changes: 27 additions & 0 deletions app/views/admin/tasks/provider_details.html.erb
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
<% content_for(:page_title) { page_title("Claim #{@claim.reference} provider details check for #{@claim.policy.short_name}") } %>

<% content_for :back_link do %>
<%= govuk_back_link href: admin_claim_tasks_path(@claim) %>
<% end %>

<%= render "shared/error_summary", instance: @task, errored_field_id_overrides: { "passed": "task_passed_true" } if @task.errors.any? %>

<div class="govuk-grid-row">
<%= render claim_summary_view, claim: @claim, heading: "Subject check" %>

<div class="govuk-grid-column-two-thirds">
<h2 class="govuk-heading-l"><%= @current_task_name.humanize %></h2>

<%= render "admin/claims/answers", answers: @tasks_presenter.provider_details %>
</div>

<div class="govuk-grid-column-two-thirds">
<% if !@task.passed.nil? %>
<%= render "task_outcome", task: @task %>
<% else %>
<%= render "form", task_name: "provider_details", claim: @claim %>
<% end %>

<%= render partial: "admin/task_pagination" %>
</div>
</div>
4 changes: 4 additions & 0 deletions config/locales/en.yml
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,8 @@ en:
title: "Confirm the claimant made the claim"
provider_verification:
title: "Confirm the provider has responded and verified the claimant's information"
provider_details:
title: "Check the provider details"
payroll_gender:
title: "How is the claimant’s gender recorded for payroll purposes?"
hint: "The claimant answered ‘don’t know’ to the question ‘how is your gender recorded on your employer’s payroll system?’"
Expand Down Expand Up @@ -933,6 +935,8 @@ en:
claimant_answers:
true: "Yes"
false: "No"
provider_details:
title: "Is the claim still valid even though the claimant and provider have matching details?"
student_loan_plan:
title: "Does the claimant’s student loan plan match the information we hold about their loan?"
forms:
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
require "rails_helper"

RSpec.feature "Admin checks a further education payments claim" do
before do
sign_in_as_service_operator
end

context "when the claim has a claimant and provider with the same name" do
it "requires the admin to check for provider fraud" do
claim = create(
:claim,
:submitted,
first_name: "Walter",
middle_name: "Seymour",
surname: "Skinner",
email_address: "[email protected]",
policy: Policies::FurtherEducationPayments,
eligibility_attributes: {
verification: {
verifier: {
first_name: "Walter",
last_name: "Skinner",
email: "[email protected]"
}
}
}
)

visit admin_claim_tasks_path(claim)

expect(page).to have_content("Check the provider details")

click_on "Check the provider details"

expect(page).to have_content(
"Is the claim still valid even though the claimant and provider have matching details?"
)
end
end

context "when the claim has a claimant and provider with the same email" do
it "requires the admin to check for provider fraud" do
claim = create(
:claim,
:submitted,
first_name: "Armin",
surname: "Tamzarian",
email_address: "[email protected]",
policy: Policies::FurtherEducationPayments,
eligibility_attributes: {
verification: {
verifier: {
first_name: "Walter",
last_name: "Skinner",
email: "[email protected]"
}
}
}
)

visit admin_claim_tasks_path(claim)

expect(page).to have_content("Check the provider details")

click_on "Check the provider details"

expect(page).to have_content(
"Is the claim still valid even though the claimant and provider have matching details?"
)
end
end

context "when the claim has a claimant and provider with different details" do
it "doesn't require the admin check for provider fraud" do
claim = create(
:claim,
:submitted,
first_name: "Edna",
surname: "Krabappel",
email_address: "[email protected]",
policy: Policies::FurtherEducationPayments,
eligibility_attributes: {
verification: {
verifier: {
first_name: "Walter",
last_name: "Skinner",
email: "[email protected]"
}
}
}
)

visit admin_claim_tasks_path(claim)

expect(page).not_to have_content("Check the provider details")
end
end
end
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
:claim,
first_name: "Edna",
surname: "Krabappel",
email_address: "[email protected]",
date_of_birth: Date.new(1945, 7, 3),
reference: "AB123456",
created_at: DateTime.new(2024, 8, 1, 9, 0, 0),
Expand Down Expand Up @@ -99,6 +100,7 @@
:claim,
first_name: "Edna",
surname: "Krabappel",
email_address: "[email protected]",
date_of_birth: Date.new(1945, 7, 3),
reference: "AB123456",
created_at: DateTime.new(2024, 8, 1, 9, 0, 0),
Expand Down Expand Up @@ -178,6 +180,7 @@
:claim,
first_name: "Edna",
surname: "Krabappel",
email_address: "[email protected]",
date_of_birth: Date.new(1945, 7, 3),
reference: "AB123456",
created_at: DateTime.new(2024, 8, 1, 9, 0, 0),
Expand Down Expand Up @@ -249,6 +252,7 @@
:claim,
first_name: "Edna",
surname: "Krabappel",
email_address: "[email protected]",
date_of_birth: Date.new(1945, 7, 3),
reference: "AB123456",
created_at: DateTime.new(2024, 8, 1, 9, 0, 0),
Expand Down Expand Up @@ -295,6 +299,7 @@
:claim,
first_name: "Edna",
surname: "Krabappel",
email_address: "[email protected]",
date_of_birth: Date.new(1945, 7, 3),
reference: "AB123456",
created_at: DateTime.new(2024, 8, 1, 9, 0, 0),
Expand Down Expand Up @@ -387,6 +392,7 @@
:claim,
first_name: "Edna",
surname: "Krabappel",
email_address: "[email protected]",
date_of_birth: Date.new(1945, 7, 3),
reference: "AB123456",
created_at: DateTime.new(2024, 8, 1, 9, 0, 0),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,21 @@
let(:teacher_reference_number) { "1234567" }
let(:matching_claims) { Claim.none }
let(:hmrc_bank_validation_succeeded) { true }
let(:claimant_first_name) { "Edna" }
let(:claimant_surname) { "Krabappel" }
let(:claimant_email_address) { "[email protected]" }

let(:eligibility) do
build(
:further_education_payments_eligibility,
teacher_reference_number: teacher_reference_number
teacher_reference_number: teacher_reference_number,
verification: {
verifier: {
first_name: "Walter",
last_name: "Skinner",
email: "[email protected]"
}
}
)
end

Expand All @@ -22,7 +32,10 @@
policy: Policies::FurtherEducationPayments,
payroll_gender: payroll_gender,
hmrc_bank_validation_succeeded: hmrc_bank_validation_succeeded,
eligibility: eligibility
eligibility: eligibility,
first_name: claimant_first_name,
surname: claimant_surname,
email_address: claimant_email_address
)
end

Expand Down Expand Up @@ -83,5 +96,23 @@
it { is_expected.not_to include("payroll_details") }
it { is_expected.to include(*invariant_tasks) }
end

context "when the claimant and provider names match" do
let(:claimant_first_name) { "Walter" }
let(:claimant_surname) { "Skinner" }
it { is_expected.to include("provider_details") }
it { is_expected.to include(*invariant_tasks) }
end

context "when the claimant and provider emails match" do
let(:claimant_email_address) { "[email protected]" }
it { is_expected.to include("provider_details") }
it { is_expected.to include(*invariant_tasks) }
end

context "when the claim and provider details are different" do
it { is_expected.not_to include("provider_details") }
it { is_expected.to include(*invariant_tasks) }
end
end
end

0 comments on commit 7eeff75

Please sign in to comment.