# frozen_string_literal: true module ErrorTracking class IssueLatestEventService < ErrorTracking::BaseService private def perform response = find_issue_latest_event(params[:issue_id]) compose_response(response) end def parse_response(response) { latest_event: response[:latest_event] } end def find_issue_latest_event(issue_id) # There are 2 types of the data source for the error tracking feature: # # * When integrated error tracking is enabled, we use the application database # to read and save error tracking data. # # * When integrated error tracking is disabled we call # project_error_tracking_setting method which works with Sentry API. # # Issue https://gitlab.com/gitlab-org/gitlab/-/issues/329596 # if project_error_tracking_setting.integrated_client? error = project.error_tracking_errors.find(issue_id) event = error.events.last # We use the same response format as project_error_tracking_setting # method below for compatibility with existing code. { latest_event: event.to_sentry_error_event } else project_error_tracking_setting.issue_latest_event(issue_id: issue_id) end end end end