18F/identity-idp

View on GitHub
app/presenters/piv_cac_error_presenter.rb

Summary

Maintainability
A
0 mins
Test Coverage
C
77%
# frozen_string_literal: true

class PivCacErrorPresenter
  include Rails.application.routes.url_helpers
  include ActionView::Helpers::TranslationHelper

  attr_accessor :error

  def initialize(error:, view:, try_again_url:)
    @error = error
    @view = view
    @try_again_url = try_again_url
  end

  def title
    heading
  end

  def heading
    case error
    when 'piv_cac.already_associated'
      t('headings.piv_cac_setup.already_associated')
    when 'user.not_found'
      t('headings.piv_cac_login.account_not_found')
    when 'certificate.bad'
      t('headings.piv_cac.certificate.bad')
    when 'certificate.expired'
      t('headings.piv_cac.certificate.expired')
    when 'certificate.invalid'
      t('headings.piv_cac.certificate.invalid')
    when 'certificate.none'
      t('headings.piv_cac.certificate.none')
    when 'certificate.not_auth_cert'
      t('headings.piv_cac.certificate.not_auth_cert')
    when 'certificate.revoked'
      t('headings.piv_cac.certificate.revoked')
    when 'certificate.unverified'
      t('headings.piv_cac.certificate.unverified')
    when 'token.bad'
      t('headings.piv_cac.token.bad')
    when 'token.invalid'
      t('headings.piv_cac.token.invalid')
    when 'token.missing', 'token.http_failure'
      t('headings.piv_cac.token.missing')
    else
      t('headings.piv_cac.did_not_work')
    end
  end

  def description
    case error
    when 'piv_cac.already_associated'
      t('instructions.mfa.piv_cac.already_associated_html', try_again_html: try_again_link)
    when 'user.not_found'
      t(
        'instructions.mfa.piv_cac.account_not_found_html',
        app_name: APP_NAME,
        sign_in: @view.link_to(t('headings.sign_in_without_sp'), root_url),
        create_account: @view.link_to(t('links.create_account'), sign_up_email_url),
      )
    when 'certificate.none'
      t('instructions.mfa.piv_cac.no_certificate_html', try_again_html: try_again_link)
    when 'certificate.not_auth_cert'
      t('instructions.mfa.piv_cac.not_auth_cert_html', please_try_again_html: please_try_again_link)
    when 'token.http_failure'
      t('instructions.mfa.piv_cac.http_failure')
    else
      t('instructions.mfa.piv_cac.did_not_work_html', please_try_again_html: please_try_again_link)
    end
  end

  def url_options
    @view.url_options
  end

  private

  def please_try_again_link
    @view.link_to(t('instructions.mfa.piv_cac.please_try_again'), @try_again_url)
  end

  def try_again_link
    @view.link_to(t('instructions.mfa.piv_cac.try_again'), @try_again_url)
  end
end