Bug #6086 » 0001-Fixes-6086-stop-remote-command-execution-and-path-ex.patch
lib/proxy/tftp.rb | ||
---|---|---|
class << self
|
||
include Proxy::Util
|
||
def fetch_boot_file dst, src
|
||
filename = src.split("/")[-1]
|
||
destination = Pathname.new("#{SETTINGS.tftproot}/#{dst}-#{filename}")
|
||
filename = dst + '-' + src.split("/")[-1]
|
||
destination = Pathname.new(File.expand_path(filename, SETTINGS.tftproot)).cleanpath
|
||
tftproot = Pathname.new(SETTINGS.tftproot).cleanpath
|
||
raise "TFTP destination outside of tftproot" unless destination.to_s.start_with?(tftproot.to_s)
|
||
# Ensure that our image directory exists
|
||
# as the dst might contain another sub directory
|
||
FileUtils.mkdir_p destination.parent
|
||
wget = which("wget")
|
||
cmd = "#{wget} --timeout=10 --tries=3 --no-check-certificate -nv -c #{src} -O \"#{destination}\""
|
||
cmd = "#{wget} --timeout=10 --tries=3 --no-check-certificate -nv -c \"#{escape_for_shell(src.to_s)}\" -O \"#{escape_for_shell(destination.to_s)}\""
|
||
CommandTask.new(cmd)
|
||
end
|
||
end
|
test/tftp_test.rb | ||
---|---|---|
SETTINGS.stubs(:tftproot).returns("./some/root")
|
||
assert_equal Pathname.new(__FILE__).join("..", "..", "lib","proxy","some","root").to_s, @tftp.send(:path)
|
||
end
|
||
def test_paths_inside_tftp_directory_dont_raise_errors
|
||
SETTINGS.stubs(:tftproot).returns("/some/root")
|
||
Proxy::Util::CommandTask.stubs(:new).returns(true)
|
||
FileUtils.stubs(:mkdir_p).returns(true)
|
||
assert Proxy::TFTP.send(:fetch_boot_file,'/some/root/boot/file','http://localhost/file')
|
||
end
|
||
def test_paths_outside_tftp_directory_raise_errors
|
||
SETTINGS.stubs(:tftproot).returns("/some/root")
|
||
Proxy::Util::CommandTask.stubs(:new).returns(true)
|
||
FileUtils.stubs(:mkdir_p).returns(true)
|
||
assert_raises RuntimeError do
|
||
Proxy::TFTP.send(:fetch_boot_file,'/other/root/boot/file','http://localhost/file')
|
||
end
|
||
end
|
||
end
|
- « Previous
- 1
- 2
- 3
- 4
- Next »