Sha256: 14c051c1c6b11da59a2cee5ce7522fe6d5112c0242c995956489a75792f51861

Contents?: true

Size: 777 Bytes

Versions: 47

Compression:

Stored size: 777 Bytes

Contents

module Puma
  class TCPLogger
    def initialize(logger, app, quiet=false)
      @logger = logger
      @app = app
      @quiet = quiet
    end

    FORMAT = "%s - %s"

    def log(who, str)
      now = Time.now.strftime("%d/%b/%Y %H:%M:%S")

      log_str = "#{now} - #{who} - #{str}"

      case @logger
      when IO
        @logger.puts log_str
      when Events
        @logger.log log_str
      end
    end

    def call(env, socket)
      who = env[Const::REMOTE_ADDR]
      log who, "connected" unless @quiet

      env['log'] = lambda { |str| log(who, str) }

      begin
        @app.call env, socket
      rescue Object => e
        log who, "exception: #{e.message} (#{e.class})"
      else
        log who, "disconnected" unless @quiet
      end
    end
  end
end

Version data entries

47 entries across 45 versions & 3 rubygems

Version Path
puma-3.12.0-java lib/puma/tcp_logger.rb
puma-3.12.0 lib/puma/tcp_logger.rb
puma-3.11.4-java lib/puma/tcp_logger.rb
puma-3.11.4 lib/puma/tcp_logger.rb
tdiary-5.0.8 vendor/bundle/gems/puma-3.11.3/lib/puma/tcp_logger.rb
puma-3.11.3-java lib/puma/tcp_logger.rb
puma-3.11.3 lib/puma/tcp_logger.rb
puma-3.11.2-java lib/puma/tcp_logger.rb
puma-3.11.2 lib/puma/tcp_logger.rb
puma-3.11.1-java lib/puma/tcp_logger.rb
puma-3.11.1 lib/puma/tcp_logger.rb
puma-3.11.0-java lib/puma/tcp_logger.rb
puma-3.11.0 lib/puma/tcp_logger.rb
puma-3.10.0-java lib/puma/tcp_logger.rb
puma-3.10.0 lib/puma/tcp_logger.rb
tdiary-5.0.5 vendor/bundle/gems/puma-3.8.2/lib/puma/tcp_logger.rb
tdiary-5.0.5 vendor/bundle/gems/puma-3.9.1/lib/puma/tcp_logger.rb
tdiary-5.0.5 vendor/bundle/gems/tdiary-5.0.4/vendor/bundle/gems/puma-3.8.2/lib/puma/tcp_logger.rb
puma-3.9.1-java lib/puma/tcp_logger.rb
puma-3.9.1 lib/puma/tcp_logger.rb