我有一个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只有动作和控制器信息。
答案 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