2014-11-03 22:20:21 +00:00
|
|
|
# -*- coding: binary -*-
|
|
|
|
|
|
|
|
module Msf
|
|
|
|
|
|
|
|
###
|
|
|
|
#
|
|
|
|
# File system path option.
|
|
|
|
#
|
|
|
|
###
|
|
|
|
class OptPath < OptBase
|
|
|
|
def type
|
|
|
|
return 'path'
|
|
|
|
end
|
|
|
|
|
2016-02-03 22:37:29 +00:00
|
|
|
def normalize(value)
|
2016-02-03 22:53:47 +00:00
|
|
|
value.nil? ? value : File.expand_path(value)
|
2016-02-03 22:37:29 +00:00
|
|
|
end
|
|
|
|
|
2016-03-29 04:03:17 +00:00
|
|
|
def validate_on_assignment?
|
|
|
|
false
|
|
|
|
end
|
|
|
|
|
2014-11-03 22:20:21 +00:00
|
|
|
# Generally, 'value' should be a file that exists.
|
2016-05-23 19:56:19 +00:00
|
|
|
def valid?(value, check_empty: true)
|
|
|
|
return false if check_empty && empty_required_value?(value)
|
2014-11-03 22:20:21 +00:00
|
|
|
if value and !value.empty?
|
|
|
|
if value =~ /^memory:\s*([0-9]+)/i
|
|
|
|
return false unless check_memory_location($1)
|
|
|
|
else
|
2016-05-24 20:53:26 +00:00
|
|
|
unless File.exist?(File.expand_path(value))
|
2014-11-03 22:20:21 +00:00
|
|
|
return false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return super
|
|
|
|
end
|
|
|
|
|
|
|
|
# The AuthBrute mixin can take a memory address as well --
|
|
|
|
# currently, no other OptFile can make use of these objects.
|
|
|
|
# TODO: Implement memory:xxx to be more generally useful so
|
|
|
|
# the validator on OptFile isn't lying for non-AuthBrute.
|
|
|
|
def check_memory_location(id)
|
|
|
|
return false unless self.class.const_defined?(:ObjectSpace)
|
|
|
|
obj = ObjectSpace._id2ref(id.to_i) rescue nil
|
|
|
|
return false unless obj.respond_to? :acts_as_file?
|
|
|
|
return false unless obj.acts_as_file? # redundant?
|
|
|
|
return !!obj
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|