如何将用户信息添加到Airbrake通知中?

时间:2017-02-28 12:53:12

标签: ruby-on-rails airbrake

我有一个Rails应用程序正在发送Airbrake通知,但我想在通知中添加一些用户信息。

我正在使用airbrake gem,v5.7.1,它会添加middleware来捕获未捕获的异常并在重新提升之前报告它们。

我按照README尝试向初始化程序添加过滤器:

class UserDetailsFilter
  def call(notice)
    if notice.stash.has_key?(:rack_request)
      user_credentials = notice.stash[:rack_request].cookies["user_credentials"]          
      unless user_credentials.blank?
        user_id = user_credentials.split(':').last
        user = User.find(user_id)
        notice[:params][:user_email] = user.email
        notice[:params][:user_name] = "#{user.first_name} #{user.last_name}"
      end
    end 
  end
end

Airbrake.add_filter(UserDetailsFilter.new)

使用binding.pry我可以确认此代码已运行且该通知确实已修改:params哈希值。然而,Airbrake UI中的params只有动作和控制器信息。

2 个答案:

答案 0 :(得分:1)

这是Airbrake宝石中的一个错误,已经修复并在Airbrake 5.8.0中发布。

答案 1 :(得分:0)

我不确定为什么这些信息没有显示在仪表板中,它应该用params显示就好了。

Airbrake gem根据https://airbrake.io/docs/api/#create-notice-v3将用户信息设置为notice[:context][:user]。您可以尝试在那里设置该信息。

或者,如果您可以定义带有用户对象的current_user方法,那么库可以猜测您尝试为您检索的值。

def current_user
  @current_user ||= User.find(user_id)
end