Class: V1::HigherLevelReviews::ContestableIssuesController

Inherits:
AppealsBaseControllerV1 show all
Defined in:
app/controllers/v1/higher_level_reviews/contestable_issues_controller.rb

Constant Summary

Constants inherited from ApplicationController

ApplicationController::VERSION_STATUS

Constants included from SignIn::Authentication

SignIn::Authentication::BEARER_PATTERN

Constants included from ExceptionHandling

ExceptionHandling::SKIP_SENTRY_EXCEPTION_TYPES

Instance Attribute Summary

Attributes inherited from ApplicationController

#current_user

Instance Method Summary collapse

Methods inherited from AppealsBaseControllerV1

#decision_review_service, #get_hash_from_request_body, #request_body_debug_data, #request_body_hash, #request_body_is_not_a_hash_error

Methods included from FailedRequestLoggable

#current_user_hash, #log_exception_to_personal_information_log

Methods inherited from ApplicationController

#clear_saved_form, #cors_preflight, #pagination_params, #render_job_id, #routing_error, #set_csrf_header

Methods included from Traceable

#set_trace_tags

Methods included from SentryControllerLogging

#set_tags_and_extra_context, #tags_context, #user_context

Methods included from SentryLogging

#log_exception_to_sentry, #log_message_to_sentry, #non_nil_hash?, #normalize_level, #rails_logger, #set_sentry_metadata

Methods included from Instrumentation

#append_info_to_payload

Methods included from SignIn::Authentication

#access_token, #access_token_authenticate, #authenticate, #authenticate_access_token, #bearer_token, #cookie_access_token, #handle_authenticate_error, #load_user, #load_user_object, #scrub_bearer_token, #validate_request_ip

Methods included from Headers

#set_app_info_headers

Methods included from ExceptionHandling

#render_errors, #report_mapped_exception, #report_original_exception, #skip_sentry_exception?, #skip_sentry_exception_types

Methods included from AuthenticationAndSSOConcerns

#authenticate, #clear_session, #extend_session!, #load_user, #log_sso_info, #render_unauthorized, #reset_session, #set_api_cookie!, #set_current_user, #set_session_expiration_header, #set_session_object, #sign_in_service_exp_time, #sign_in_service_session, #sso_cookie_content, #sso_logging_info, #validate_inbound_login_params, #validate_session

Methods included from SignIn::AudienceValidator

#authenticate, #validate_audience!

Instance Method Details

#indexObject



8
9
10
11
12
13
14
15
16
17
18
19
20
# File 'app/controllers/v1/higher_level_reviews/contestable_issues_controller.rb', line 8

def index
  ci = decision_review_service
       .get_higher_level_review_contestable_issues(user: current_user, benefit_type: params[:benefit_type])
       .body
  render json: merge_legacy_appeals(ci)
rescue => e
  log_exception_to_personal_information_log(
    e,
    error_class: "#{self.class.name}#index exception #{e.class} (HLR_V1)",
    benefit_type: params[:benefit_type]
  )
  raise
end

#merge_legacy_appeals(contestable_issues) ⇒ Object (private)



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'app/controllers/v1/higher_level_reviews/contestable_issues_controller.rb', line 24

def merge_legacy_appeals(contestable_issues)
  # Fetch Legacy Appels and combine with CIs
  ci_la = nil
  begin
    la = decision_review_service
         .get_legacy_appeals(user: current_user)
         .body
    # punch in an empty LA section if no LAs for user to distinguish no LAs from a LA call fail
    la['data'] = [{ 'type': 'legacyAppeal', 'attributes': { 'issues': [] } }] if la['data'].empty?
    ci_la = { "data": contestable_issues['data'] + la['data'] }
  rescue => e
    # If LA fails keep going Legacy Appeals are not critical, return original contestable_issues
    log_exception_to_personal_information_log(
      e,
      error_class: "#{self.class.name}#index exception #{e.class} (HLR_V1_LEGACY_APPEALS)",
      benefit_type: params[:benefit_type]
    )
    contestable_issues
  else
    ci_la
  end
end