Sha256: f8abdb3503737662fa22017f98f140bf1f1c2da046a6b02ea9003047b8f420d2

Contents?: true

Size: 1.15 KB

Versions: 1

Compression:

Stored size: 1.15 KB

Contents

class ApplicationController < Sinatra::Base
  LOGGER = if (settings.logging == !!settings.logging)
    Lumberjack::Logger.new $stdout
  else
    Lumberjack::Logger.new $stdout, level: settings.logging
  end

  set :logger, LOGGER

  class DummyLogger
    def initialize(silence = false, stdout = nil)
      @silence = silence
      @stdout = stdout
    end

    def method_missing(m, *args, &block)
      LOGGER.send(m, *args, &block)
      $stdout.reopen(@stdout) if @silence
    end
  end

  helpers do
    def logger()
      if settings.logging
        return DummyLogger.new
      else
        stdout = $stdout.clone
        $stdout.reopen IO::NULL
        return DummyLogger.new(true, stdout)
      end
    end
  end

  private_constant :DummyLogger

  if settings.log_file
    time = Time.now.strftime settings.log_directory_format # Sanitize time!
    path = Eucalypt.path('logs', time)

    require 'fileutils'
    FileUtils.mkdir_p path

    $stderr.reopen File.new(File.join(path, "#{settings.environment}.stderr.log"), 'a+')
    $stderr.sync = true
    $stdout.reopen File.new(File.join(path, "#{settings.environment}.stdout.log"), 'a+')
    $stdout.sync = true
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
eucalypt-0.4.1 lib/eucalypt/core/helpers/logging.rb