Skip to content

Commit

Permalink
Rewrite query with active record
Browse files Browse the repository at this point in the history
Adds a new scope to claim  `with_award_amount` allowing for querying
claims in the db by their award amount.
  • Loading branch information
rjlynch committed Oct 14, 2024
1 parent 2362a9c commit 257cbc7
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 34 deletions.
22 changes: 22 additions & 0 deletions app/models/claim.rb
Original file line number Diff line number Diff line change
Expand Up @@ -214,6 +214,28 @@ class Claim < ApplicationRecord
.where("further_education_payments_eligibilities.verification = '{}'")
end

scope :with_award_amounts, -> do
joins(
<<~SQL
JOIN (
#{
Policies::POLICIES.map do |policy|
"
SELECT
id,
#{policy.award_amount_column} AS award_amount,
'#{policy::Eligibility}' AS eligibility_type
FROM #{policy::Eligibility.table_name}
"
end.join(" UNION ALL ")
}
) AS eligibilities
ON claims.eligibility_id = eligibilities.id
AND claims.eligibility_type = eligibilities.eligibility_type
SQL
)
end

def onelogin_idv_full_name
"#{onelogin_idv_first_name} #{onelogin_idv_last_name}"
end
Expand Down
54 changes: 20 additions & 34 deletions app/models/payroll_run.rb
Original file line number Diff line number Diff line change
Expand Up @@ -84,48 +84,34 @@ def payments_count
@payments_count ||= payments.count
end

class LineItem < Struct.new(:id, :award_amount, keyword_init: true); end

def line_items(policy, filter: :all)
eligibilities_cte = "WITH eligibilities AS("
eligibilities_cte += Policies::POLICIES.map do |policy|
<<~SQL
SELECT
id,
#{policy.award_amount_column} AS award_amount,
'#{policy::Eligibility}' AS eligibility_type
FROM #{policy::Eligibility.table_name}
SQL
end.join(" UNION ALL ")
eligibilities_cte += ")"

sql = <<~SQL
#{eligibilities_cte}
SELECT
/* A topup is always paid in different payment/payroll_run than the main claim was */
scope = Claim
.select(
"
DISTINCT(claims.id),
COALESCE(topups.award_amount, eligibilities.award_amount) AS award_amount
FROM payments
JOIN claim_payments ON claim_payments.payment_id = payments.id
JOIN claims ON claims.id = claim_payments.claim_id
JOIN eligibilities
ON claims.eligibility_id = eligibilities.id
AND claims.eligibility_type = eligibilities.eligibility_type
LEFT JOIN topups ON topups.claim_id = claims.id
WHERE payments.payroll_run_id = '#{id}'
SQL

unless policy == :all
sql += "\nAND claims.eligibility_type = 'Policies::#{policy}::Eligibility'"
end
"
)
.with_award_amounts
.left_joins(:topups)
.joins(payments: :payroll_run)
.where(payroll_runs: {id: id})

scope = scope.by_policy(policy) unless policy == :all

case filter
when :all
sql
when :claims
sql += "\nAND topups.id IS NULL"
scope = scope.where(topups: {id: nil})
when :topups
sql += "\nAND topups.id IS NOT NULL"
scope = scope.where.not(topups: {id: nil})
end

ActiveRecord::Base.connection.execute(sql).map(&OpenStruct.method(:new))
# Claim delegates it's award amount to eligibility, so we want to return
# a non claim object ensuring the award amount is from the topup if there
# is one
ActiveRecord::Base.connection.execute(scope.to_sql).map(&LineItem.method(:new))
end

def ensure_no_payroll_run_this_month
Expand Down

0 comments on commit 257cbc7

Please sign in to comment.