Files
metasploit-gs/lib/msf/core/exception.rb
T
2021-09-02 13:00:01 +01:00

325 lines
6.0 KiB
Ruby

# -*- coding: binary -*-
require 'rex/exceptions'
module Msf
###
#
# Mixin that should be included in all exceptions that can be raised from the
# framework so that they can be universally caught. Framework exceptions
# automatically extended Rex exceptions
#
###
module Exception
include Rex::Exception
end
###
#
# This exception is raised when one or more options failed
# to pass data store validation. The list of option names
# can be obtained through the options attribute.
#
# A human readable error can be associated with each option,
# which can contain additional detail / context on why the
# option validation failed.
#
###
class OptionValidateError < ArgumentError
include Exception
def initialize(options = [], reasons: {}, message: nil)
if options.is_a?(Hash)
@options = options.keys
@reasons = options
else
@options = options
@reasons = reasons
end
@reasons = @reasons.transform_values { |value| Array(value) }
super(message || "The following options failed to validate: #{@options.join(', ')}.")
end
attr_reader :options, :reasons
end
###
#
# This exception is raised when something failed to validate properly.
#
###
class ValidationError < ArgumentError
include Exception
def initialize(msg="One or more requirements could not be validated.")
super(msg)
end
end
###
#
# This exception is raised when the module cache is invalidated. It is
# handled internally by the ModuleManager.
#
###
class ModuleCacheInvalidated < RuntimeError
end
##
#
# Encoding exceptions
#
##
###
#
# This exception is raised to indicate that an encoding error of some sort has
# occurred.
#
###
class EncodingError < RuntimeError
include Exception
def initialize(msg = "An encoding exception occurred.")
super(msg)
end
end
###
#
# Thrown when an encoder fails to find a viable encoding key.
#
###
class NoKeyError < EncodingError
def initialize(msg="A valid encoding key could not be found.")
super(msg)
end
end
###
#
# Thrown when an encoder fails to encode a buffer due to a bad character.
#
###
class BadcharError < EncodingError
def initialize(buf = nil, index = nil, stub_size = nil, char = nil)
@buf = buf
@index = index
@stub_size = stub_size
@char = char
end
def to_s
# Deal with elements of a String being an instance of String instead of
# Integer in ruby 1.9.
if (char.respond_to? :ord)
c = char.ord
else
c = char
end
if (c)
return "Encoding failed due to a bad character (index=#{index}, char=#{sprintf("0x%.2x", c)})"
else
return "Encoding failed due to a nil character"
end
end
attr_reader :buf, :index, :stub_size, :char
end
###
#
# This exception is raised when no encoders succeed to encode a buffer.
#
###
class NoEncodersSucceededError < EncodingError
def initialize(msg="No encoders encoded the buffer successfully.")
super(msg)
end
end
###
#
# Thrown when an encoder fails to generate a valid opcode sequence.
#
###
class BadGenerateError < EncodingError
def initialize(msg="A valid opcode permutation could not be found.")
super(msg)
end
end
##
#
# Exploit exceptions
#
##
###
#
# This exception is raised to indicate a general exploitation error.
#
###
module ExploitError
include Exception
def initialize(msg="An exploitation error occurred.")
super(msg)
end
end
###
#
# This exception is raised to indicate a general auxiliary error.
#
###
module AuxiliaryError
include Exception
def initialize(msg="An auxiliary error occurred.")
super(msg)
end
end
###
#
# This exception is raised if a target was not specified when attempting to
# exploit something.
#
###
class MissingTargetError < ArgumentError
include ExploitError
def initialize(msg="A target has not been selected.")
super(msg)
end
end
###
#
# This exception is raised if a payload was not specified when attempting to
# exploit something.
#
###
class MissingPayloadError < ArgumentError
include ExploitError
def initialize(msg="A payload has not been selected.")
super(msg)
end
end
###
#
# This exception is raised if a valid action was not specified when attempting to
# run an auxiliary module.
#
###
class MissingActionError < ArgumentError
include AuxiliaryError
attr_accessor :reason
def initialize(reason='')
@reason = reason
super("Invalid action: #{@reason}")
end
end
###
#
# This exception is raised if an incompatible payload was specified when
# attempting to exploit something.
#
###
class IncompatiblePayloadError < ArgumentError
include ExploitError
def initialize(pname = nil)
@pname = pname
super("#{pname} is not a compatible payload.")
end
#
# The name of the payload that was used.
#
attr_reader :pname
end
class NoCompatiblePayloadError < ArgumentError
include Exception
end
##
#
# NOP exceptions
#
##
###
#
# This exception is raised to indicate that a general NOP error occurred.
#
###
module NopError
include Exception
def initialize(msg="A NOP generator error occurred.")
super(msg)
end
end
###
#
# This exception is raised when no NOP generators succeed at generating a
# sled.
#
###
class NoNopsSucceededError < RuntimeError
include NopError
def initialize(msg="No NOP generators succeeded.")
super(msg)
end
end
##
#
# Plugin exceptions
#
##
class PluginLoadError < RuntimeError
include Exception
attr_accessor :reason
def initialize(reason='')
@reason = reason
super("This plugin failed to load: #{reason}")
end
end
##
#
# This exception is raised if a payload option string exceeds the maximum
# allowed size during the payload generation.
#
##
class PayloadItemSizeError < ArgumentError
include Exception
def initialize(item = nil, max_size = nil)
@item = item
@max_size = max_size
end
def to_s
"Option value: #{item.slice(0..30)} is too big (Current length: #{item.length}, Maximum length: #{max_size})."
end
attr_reader :item # The content of the payload option (for example a URL)
attr_reader :max_size # The maximum allowed size of the payload option
end
end