Rubyipmi::Ipmitool::BaseCommand

Public Instance Methods

find_fix(result) click to toggle source

The findfix method acts like a recursive method and applies fixes defined in the errorcodes If a fix is found it is applied to the options hash, and then the last run command is retried until all the fixes are exhausted or a error not defined in the errorcodes is found

# File lib/rubyipmi/ipmitool/commands/basecommand.rb, line 39
def find_fix(result)
  if result
    # The errorcode code hash contains the fix
    begin
      fix = ErrorCodes.search(result)
      @options.merge_notify!(fix)

    rescue
      raise "Could not find fix for error code: \n#{result}"
    end
  end
end
makecommand() click to toggle source
# File lib/rubyipmi/ipmitool/commands/basecommand.rb, line 19
def makecommand
  args = ''
  # need to format the options to ipmitool format
  @options.each do  |k,v|
    # must remove from command line as its handled via conf file
    next if k == "P"
    next if k == "cmdargs"
    args << " -#{k} #{v}"
  end

  # since ipmitool requires commands to be in specific order

  args << ' ' + options.fetch('cmdargs', '')

  return "#{cmd} #{args.lstrip}"
end
max_retry_count() click to toggle source
# File lib/rubyipmi/ipmitool/commands/basecommand.rb, line 15
def max_retry_count
  @max_retry_count ||= Rubyipmi::Ipmitool::ErrorCodes.length
end
setpass() click to toggle source
# File lib/rubyipmi/ipmitool/commands/basecommand.rb, line 7
def setpass
  super
  @options["f"] = @passfile.path
  @passfile.write "#{@options["P"]}"
  @passfile.rewind
  @passfile.close
end

[Validate]

Generated with the Darkfish Rdoc Generator 2.