Class: AppealsBaseController
- Inherits:
-
ApplicationController
- Object
- ActionController::API
- ApplicationController
- AppealsBaseController
- Includes:
- FailedRequestLoggable
- Defined in:
- app/controllers/appeals_base_controller.rb
Direct Known Subclasses
V0::AppealsController, V0::VirtualAgent::VirtualAgentAppealController
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
Instance Method Summary collapse
- #appeals_service ⇒ Object private
- #decision_review_service ⇒ Object private
- #get_hash_from_request_body ⇒ Object private
- #request_body_debug_data ⇒ Object private
- #request_body_hash ⇒ Object private
- #request_body_is_not_a_hash_error ⇒ Object private
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
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
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
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
#appeals_service ⇒ Object (private)
12 13 14 |
# File 'app/controllers/appeals_base_controller.rb', line 12 def appeals_service Caseflow::Service.new end |
#decision_review_service ⇒ Object (private)
16 17 18 |
# File 'app/controllers/appeals_base_controller.rb', line 16 def decision_review_service DecisionReview::Service.new end |
#get_hash_from_request_body ⇒ Object (private)
24 25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'app/controllers/appeals_base_controller.rb', line 24 def get_hash_from_request_body # rubocop:disable Style/ClassEqualityComparison # testing string b/c NullIO class doesn't always exist raise request_body_is_not_a_hash_error if request.body.class.name == 'Puma::NullIO' # rubocop:enable Style/ClassEqualityComparison body = JSON.parse request.body.string raise request_body_is_not_a_hash_error unless body.is_a?(Hash) body rescue JSON::ParserError raise request_body_is_not_a_hash_error end |
#request_body_debug_data ⇒ Object (private)
42 43 44 45 46 47 |
# File 'app/controllers/appeals_base_controller.rb', line 42 def request_body_debug_data { request_body_class_name: request.try(:body).class.name, request_body_string: request.try(:body).try(:string) } end |
#request_body_hash ⇒ Object (private)
20 21 22 |
# File 'app/controllers/appeals_base_controller.rb', line 20 def request_body_hash @request_body_hash ||= get_hash_from_request_body end |
#request_body_is_not_a_hash_error ⇒ Object (private)
38 39 40 |
# File 'app/controllers/appeals_base_controller.rb', line 38 def request_body_is_not_a_hash_error DecisionReview::ServiceException.new key: 'DR_REQUEST_BODY_IS_NOT_A_HASH' end |