Sha256: dffba1927bc247664745ca1663c9eb4466528420b41ce493effb503ceb892bb6

Contents?: true

Size: 1.37 KB

Versions: 4

Compression:

Stored size: 1.37 KB

Contents

class LogLocationCache
  TIME_LIMIT = 6000

  def initialize
    clear
  end

  def [](pid)
    pid = pid.to_i
    unless pids.include?(pid)
      set_pid_log_location(pid, get_pid_location(pid))
    end
    pids[pid][:value]
  end

private
  attr_accessor :query_counter
  attr_accessor :pids

  def clear
    self.query_counter = 0
    self.pids = {}
    self
  end

  def remove_old_values
    self.query_counter = query_counter + 1
    if query_counter < 1000
      return
    end
    self.query_counter = 0
    limit = Time.now - TIME_LIMIT
    pids.keys.each do |pid|
      if pids[pid][:time] < limit
        pids.remove(pid)
      end
    end
    self
  end

  def get_pid_location(lpid)
    folder = log_folder(lpid)
    return nil if folder.nil?
    File.join(folder, 'current')
  end

  def log_command(lpid)
    return nil if lpid.nil?
    ps_output = `ps -o args -p #{lpid} 2>&1`.split("\n")
    ps_output.shift
    cmd = ps_output.first
    cmd = cmd.chomp unless cmd.nil?
    cmd = nil if cmd == ''
    cmd
  end

  def log_folder(lpid)
    cmd = log_command(lpid)
    return nil if cmd.nil?
    args = cmd.split(/\s+/).select { |arg| arg !~ /^\-/ }
    return nil if args.shift !~ /svlogd/
    args.shift
  end

  def set_pid_log_location(pid, log_location)
    remove_old_values
    pids[pid.to_i] = {
      :value => log_location,
      :time  => Time.now
    }
    self
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
runit-man-1.7.3 lib/runit-man/log_location_cache.rb
runit-man-1.7.2 lib/runit-man/log_location_cache.rb
runit-man-1.7.1 lib/runit-man/log_location_cache.rb
runit-man-1.7.0 lib/runit-man/log_location_cache.rb