如何向现有Notifications有效负载添加属性?

时间:2012-11-29 19:38:19

标签: ruby-on-rails ruby-on-rails-3

在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

2 个答案:

答案 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]

让我知道你是如何继续下去的,我会更多地尝试帮助,遗憾的是这些东西确实没有文档。