gitlab-org--gitlab-foss/app/models/concerns/integrations/loggable.rb

38 lines
808 B
Ruby

# frozen_string_literal: true
module Integrations
module Loggable
def log_info(message, params = {})
message = build_message(message, params)
logger.info(message)
end
def log_error(message, params = {})
message = build_message(message, params)
logger.error(message)
end
def log_exception(error, params = {})
Gitlab::ExceptionLogFormatter.format!(error, params)
log_error(params[:message] || error.message, params)
end
def build_message(message, params = {})
{
integration_class: self.class.name,
integration_id: id,
project_id: project&.id,
project_path: project&.full_path,
message: message
}.merge(params)
end
def logger
Gitlab::IntegrationsLogger
end
end
end