在Rails通知中,我订阅了“process_action.action_controller”,并希望向有效负载添加更多属性。我怎么能这样做?
我尝试过使用append_info_to_payload,但这似乎什么也没做。
module AppendExceptionPayload
module ControllerRuntime
extend ActiveSupport::Concern
protected
def append_info_to_payload(payload)
super
payload[:happy] = "HAPPY"
end
end
end
订阅和上面的代码在Rails引擎中,所以我在这里调用它来添加它:
require 'append_exception_payload'
module Instrument
class Engine < ::Rails::Engine
ActiveSupport.on_load :action_controller do
include AppendExceptionPayload::ControllerRuntime
end
end
end
答案 0 :(得分:6)
在提出赏金之后,我自己找到了一个解决方案。 Rails非常干净地处理这个问题。
基本上,append_info_to_payload
方法完全是为了这个。
为了包含会话信息和signed_in用户信息,我将其添加到我的application_controller.rb
:
def append_info_to_payload(payload)
super
payload[:session] = request.session_options[:id] rescue ""
payload[:user_id] = session[:user_id] rescue "unknown"
end
答案 1 :(得分:2)
所以我跳了进去看了process_action method (private)和append_info_to_payload instance method (public)的api,并且proccess action方法似乎在其代码中调用了append_info_to_payload,如下所示:
ActiveSupport::Notifications.instrument("process_action.action_controller", raw_payload) do |payload|
result = super
payload[:status] = response.status
append_info_to_payload(payload)
result
end
和append_info_to_payload的工作原理如下
def append_info_to_payload(payload) #:nodoc:
payload[:view_runtime] = view_runtime
end
我可以建议您尝试payload[:view_runtime]
代替payload[:happy]
或尝试使用payload[:status]
让我知道你是如何继续下去的,我会更多地尝试帮助,遗憾的是这些东西确实没有文档。