18F/identity-idp

View on GitHub
app/services/verification_failures_report.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
# frozen_string_literal: true

class VerificationFailuresReport
  def self.call(service_provider, start_time, end_time)
    report_sql = <<~SQL
      SELECT 
        agency_identities.uuid,
        document_capture_submit_at,
        back_image_submit_at,
        capture_mobile_back_image_submit_at,
        mobile_back_image_submit_at,
        encrypt_view_at,
        enter_info_view_at,
        ssn_view_at,
        verify_phone_submit_at,
        verify_phone_view_at,
        verify_submit_at,
        welcome_view_at
      FROM doc_auth_logs, users, agency_identities, service_providers
      WHERE 
        users.id=doc_auth_logs.user_id AND 
        service_providers.issuer = %{issuer} AND 
        agency_identities.agency_id = service_providers.agency_id AND 
        agency_identities.user_id = users.id AND 
        doc_auth_logs.issuer=%{issuer} AND
        verified_view_at is null AND
        %{start_time} <= welcome_view_at AND welcome_view_at <= %{end_time}
      ORDER BY agency_identities.uuid ASC
    SQL
    sql = format(
      report_sql,
      issuer: ActiveRecord::Base.connection.quote(service_provider),
      start_time: ActiveRecord::Base.connection.quote(start_time),
      end_time: ActiveRecord::Base.connection.quote(end_time),
    )
    ActiveRecord::Base.connection.execute(sql)
  end
end