Sha256: 4ec63fbe8637063349f6be569bee6d9c481724bdc740293690f4dcbfcf858b64
Contents?: true
Size: 1.96 KB
Versions: 1
Compression:
Stored size: 1.96 KB
Contents
module Rack module Logs class Viewer def initialize config @config = config end attr_reader :config def call env contents = joined_logs(env.fetch('PATH_INFO','/')) if contents.empty? [404, headers, ['No Such File']] else [200, headers, contents] end end private def headers { 'Content-Type' => 'text/plain' } end class JoinedFiles include Enumerable def initialize filenames, lines @filenames = filenames @lines = lines end def empty? @filenames.empty? end def each &block @filenames.each do |filename| block.call "## #{filename}\n\n" ::File.open(filename) do |file| total = 0 file.each_line { total += 1 } progress = 0 file.rewind file.each_line do |line| if progress > (total - @lines) block.call line end progress += 1 end end end end private def tail file, n index = 1 lines = 0 buffer = "" begin file.seek(index * (1024 * -1), :END) chunk = file.read(1024) lines += chunk.count("\n") buffer.prepend chunk index += 1 end while lines < n && file.pos >= 0 buffer.lines[-1 * n].join end end def joined_logs path JoinedFiles.new files(path), @config.lines end def logs files.inject({}) do |hash, filename| hash[filename] = ::File.read(filename) hash end end def files path Dir[@config.log_dir+'/'+@config.pattern].select do |filename| filename =~ Regexp.new( @config.log_dir + path ) end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
rack-logs-0.0.5 | lib/rack/logs/viewer.rb |