2014-04-07 5 views
1

누군가가이 코드의 작동 방식, 특히 로그 필터 부분을 어떻게 설명 할 수 있습니까? 랙 파일에서 log_attributes_filter을 할당하고 싶습니다. 전화 번호는 use MongodbLogger::RackMiddleware입니다. 그렇게하는 방법은 무엇입니까?랙 미들웨어 글로벌 미들웨어

내가 단순히 use MongodbLogger::RackMiddleware로 사용하지만, 지금은 약간의 PARAMS를 필터링 할 전에
# 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 

, 내가 어떻게 제대로 @@log_attributes_filter을 할당해야합니까?

+0

, 난 당신을 생각하지 않는다 당신이 그것을 현재의 능력 이상으로 확장하고 싶지 않다면 여기에 어떤 것을 써야합니다. 그렇다면 패치 https://github.com/le0pard/mongodb_logger/pull/48을 작성하면서 smotsovoy에게 문의하는 것이 좋습니다. –

답변

0

발견 방법. http://mongodb-logger.catware.org/ 및 https://github.com/le0pard/mongodb_logger이 필터는 웹 인터페이스를 통해 설정되는 것 같다 읽기에서

use MongodbLogger::RackMiddleware 
    MongodbLogger::RackMiddleware.log_attributes_filter = lambda do |request| 
    begin 
     request[:params]["Password"] = "[FILTERED]" 
     request 
    rescue 
     request 
    end 
    end 
관련 문제