【发布时间】:2014-04-07 13:25:44
【问题描述】:
谁能解释一下这种和平的代码是如何工作的,尤其是日志过滤器部分。
我想从机架文件中分配log_attributes_filter,我在其中调用use MongodbLogger::RackMiddleware,该怎么做?
# Rack middleware for mounted rack app (e.g Grape)
module MongodbLogger
class RackMiddleware
@@log_attributes_filter = nil
def self.log_attributes_filter=(filter)
@@log_attributes_filter = filter
end
def initialize(app)
@app = app
end
def call(env)
request = ::Rack::Request.new env
path = request.path.split('/')
log_attrs = {
params: request.params
}
log_attrs = @@log_attributes_filter.call(log_attrs) if @@log_attributes_filter
logger.mongoize(log_attrs) do
return @app.call(env)
end
end
end
end
之前我只是将它用作use MongodbLogger::RackMiddleware,但现在我想过滤一些参数,我应该如何正确分配@@log_attributes_filter?
【问题讨论】:
-
从阅读 mongodb-logger.catware.org 和 github.com/le0pard/mongodb_logger 看来,过滤器是通过网络界面设置的,我认为你不需要在这里写任何具体的东西,除非你想将它扩展到它之外目前的能力。如果是这种情况,我可能会考虑在 smotsovoy 编写补丁时联系他 github.com/le0pard/mongodb_logger/pull/48。
标签: ruby-on-rails ruby rack middleware rack-middleware