Simplified FlexNBD::FakeDest
This commit is contained in:
@@ -15,44 +15,31 @@ module FlexNBD
|
|||||||
|
|
||||||
|
|
||||||
def write_hello( opts = {} )
|
def write_hello( opts = {} )
|
||||||
self.class.write_hello( @sock, opts )
|
@sock.write( "NBDMAGIC" )
|
||||||
end
|
|
||||||
|
|
||||||
def read_request()
|
|
||||||
self.class.read_request( @sock )
|
|
||||||
end
|
|
||||||
|
|
||||||
def write_error( handle )
|
|
||||||
self.class.write_error( @sock, handle )
|
|
||||||
end
|
|
||||||
|
|
||||||
def close
|
|
||||||
@sock.close
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
def self.write_hello( client_sock, opts={} )
|
|
||||||
client_sock.write( "NBDMAGIC" )
|
|
||||||
|
|
||||||
if opts[:magic] == :wrong
|
if opts[:magic] == :wrong
|
||||||
client_sock.write( "\x00\x00\x42\x02\x81\x86\x12\x52" )
|
write_rand( @sock, 8 )
|
||||||
else
|
else
|
||||||
client_sock.write( "\x00\x00\x42\x02\x81\x86\x12\x53" )
|
@sock.write( "\x00\x00\x42\x02\x81\x86\x12\x53" )
|
||||||
end
|
end
|
||||||
|
|
||||||
if opts[:size] == :wrong
|
if opts[:size] == :wrong
|
||||||
8.times do client_sock.write rand(256).chr end
|
write_rand( @sock, 8 )
|
||||||
else
|
else
|
||||||
client_sock.write( "\x00\x00\x00\x00\x00\x00\x10\x00" )
|
@sock.write( "\x00\x00\x00\x00\x00\x00\x10\x00" )
|
||||||
end
|
end
|
||||||
|
|
||||||
client_sock.write( "\x00" * 128 )
|
@sock.write( "\x00" * 128 )
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
def write_rand( sock, len )
|
||||||
|
len.times do sock.write( rand(256).chr ) end
|
||||||
|
end
|
||||||
|
|
||||||
def self.read_request( client_sock )
|
|
||||||
req = client_sock.read(28)
|
def read_request()
|
||||||
|
req = @sock.read(28)
|
||||||
|
|
||||||
magic_s = req[0 ... 4 ]
|
magic_s = req[0 ... 4 ]
|
||||||
type_s = req[4 ... 8 ]
|
type_s = req[4 ... 8 ]
|
||||||
@@ -64,12 +51,25 @@ module FlexNBD
|
|||||||
:magic => magic_s,
|
:magic => magic_s,
|
||||||
:type => type_s.unpack("N").first,
|
:type => type_s.unpack("N").first,
|
||||||
:handle => handle_s,
|
:handle => handle_s,
|
||||||
:from => parse_be64( from_s ),
|
:from => self.class.parse_be64( from_s ),
|
||||||
:len => len_s.unpack( "N").first
|
:len => len_s.unpack( "N").first
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
def write_error( handle )
|
||||||
|
@sock.write( "\x67\x44\x66\x98" )
|
||||||
|
@sock.write( "\x00\x00\x00\x01" )
|
||||||
|
@sock.write( handle )
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
def close
|
||||||
|
@sock.close
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def self.parse_be64(str)
|
def self.parse_be64(str)
|
||||||
raise "String is the wrong length: 8 bytes expected (#{str.length} received)" unless
|
raise "String is the wrong length: 8 bytes expected (#{str.length} received)" unless
|
||||||
str.length == 8
|
str.length == 8
|
||||||
@@ -79,40 +79,20 @@ module FlexNBD
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
def self.write_error( client_sock, handle )
|
|
||||||
client_sock.write( "\x67\x44\x66\x98")
|
|
||||||
client_sock.write( "\x00\x00\x00\x01")
|
|
||||||
client_sock.write( handle )
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
end # class Client
|
end # class Client
|
||||||
|
|
||||||
|
|
||||||
def initialize( addr, port )
|
def initialize( addr, port )
|
||||||
@sock = self.class.serve( addr, port )
|
@sock = TCPServer.new( addr, port )
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
def accept( err_msg = "Timed out waiting for a connection", timeout = 2)
|
def accept( err_msg = "Timed out waiting for a connection", timeout = 2)
|
||||||
Client.new( self.class.accept( @sock, err_msg, timeout ) )
|
|
||||||
end
|
|
||||||
|
|
||||||
def close
|
|
||||||
@sock.close
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
def self.serve( addr, port )
|
|
||||||
TCPServer.new( addr, port )
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
def self.accept( sock, err_msg, timeout )
|
|
||||||
client_sock = nil
|
client_sock = nil
|
||||||
|
|
||||||
begin
|
begin
|
||||||
Timeout.timeout(timeout) do
|
Timeout.timeout(timeout) do
|
||||||
client_sock = sock.accept
|
client_sock = @sock.accept
|
||||||
end
|
end
|
||||||
rescue Timeout::Error
|
rescue Timeout::Error
|
||||||
$stderr.puts err_msg
|
$stderr.puts err_msg
|
||||||
@@ -120,8 +100,16 @@ module FlexNBD
|
|||||||
end
|
end
|
||||||
|
|
||||||
client_sock
|
client_sock
|
||||||
|
|
||||||
|
Client.new( client_sock )
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
def close
|
||||||
|
@sock.close
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
end # module FakeDest
|
end # module FakeDest
|
||||||
end # module FlexNBD
|
end # module FlexNBD
|
||||||
|
Reference in New Issue
Block a user