api/app/services/spree/api/error_handler.rb

Summary

Maintainability
A
0 mins
Test Coverage
module Spree
  module Api
    class ErrorHandler
      prepend ::Spree::ServiceModule::Base

      def call(exception:, opts: {})
        run :format_message
        run :log_error
        run :report_error
      end

      protected

      def format_message(exception:, opts:)
        message = if exception.respond_to?(:original_message)
                    exception.original_message
                  else
                    exception.message
                  end

        success(exception: exception, message: message, opts: opts)
      end

      def log_error(exception:, message:, opts:)
        Rails.logger.error message
        Rails.logger.error "User ID: #{opts[:user]&.id}" if opts[:user]
        Rails.logger.error exception.backtrace.join("\n")

        success(exception: exception, message: message, opts: opts)
      end

      def report_error(exception:, message:, opts:)
        # overwrite this method in your application to support different error handlers
        # eg. Sentry, Rollbar, etc

        success(exception: exception, message: message)
      end
    end
  end
end