Глобален междинен софтуер на Rack

Може ли някой да обясни как работи тази част от кода, особено частта за филтриране на регистрационни файлове. Искам да присвоя log_attributes_filter от rack файла, където извиквам 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?


person Petya petrov    schedule 07.04.2014    source източник
comment
От четене на mongodb-logger.catware.org и github.com/le0pard/mongodb_logger изглежда, че филтрите се задават чрез уеб интерфейса, не мисля, че трябва да пишете нещо конкретно тук, освен ако искате да го разширите отвъд настоящите му възможности. Ако случаят е такъв, може да обмисля да се обърна към smotsovoy, тъй като той написа този пач github.com/le0pard/ mongodb_logger/pull/48 .   -  person Mike H-R    schedule 07.04.2014


Отговори (1)


Намерих начин.

  use MongodbLogger::RackMiddleware
  MongodbLogger::RackMiddleware.log_attributes_filter = lambda do |request|
    begin
      request[:params]["Password"] = "[FILTERED]"
      request
    rescue
      request
    end
  end
person Petya petrov    schedule 08.04.2014