18F/identity-idp

View on GitHub
app/presenters/saml_requested_attributes_presenter.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true

class SamlRequestedAttributesPresenter
  ATTRIBUTE_TO_FRIENDLY_NAME_MAP = {
    email: :email,
    all_emails: :all_emails,
    first_name: :given_name,
    last_name: :family_name,
    dob: :birthdate,
    ssn: :social_security_number,
    phone: :phone,
    address1: :address,
    address2: :address,
    city: :address,
    state: :address,
    verified_at: :verified_at,
    zipcode: :address,
  }.freeze

  def initialize(service_provider:, ial:, vtr:, authn_request_attribute_bundle:)
    @service_provider = service_provider
    @ial = ial
    @vtr = vtr
    @authn_request_attribute_bundle = authn_request_attribute_bundle
  end

  def requested_attributes
    if identity_proofing_requested? || ialmax_requested?
      bundle.map { |attr| ATTRIBUTE_TO_FRIENDLY_NAME_MAP[attr] }.compact.uniq
    else
      attrs = [:email]
      attrs << :all_emails if bundle.include?(:all_emails)
      attrs << :verified_at if bundle.include?(:verified_at)
      attrs
    end
  end

  private

  attr_reader :service_provider, :ial, :vtr, :authn_request_attribute_bundle

  def identity_proofing_requested?
    if vtr.present?
      parsed_vectors_of_trust.any? { |vot_result| vot_result.identity_proofing? }
    else
      Vot::AcrComponentValues.by_name[ial]&.requirements&.include?(
        :identity_proofing,
      )
    end
  end

  def ialmax_requested?
    Vot::AcrComponentValues.by_name[ial]&.requirements&.include?(:ialmax)
  end

  def parsed_vectors_of_trust
    vtr.map { |vot| Vot::Parser.new(vector_of_trust: vot).parse }
  end

  def bundle
    @bundle ||= (
      authn_request_attribute_bundle || service_provider&.attribute_bundle || []
    ).map(&:to_sym)
  end
end