Wraps the low-level SFTP calls for version 5 of the SFTP protocol.
None of these protocol methods block--all of them return immediately, requiring the SSH event loop to be run while the server response is pending.
You will almost certainly never need to use this driver directly. Please see Net::SFTP::Session for the recommended interface.
Public Instance methods
Sends a FXP_OPEN packet to the server and returns the packet identifier.
The flags
parameter is either an integer (in which case it
must be a combination of the IO constants) or a string (in which case it
must be one of the mode strings that IO::open accepts). The
options
parameter is a hash that is used to construct a new
Attribute object, to pass as part of the FXP_OPEN request.
# File lib/net/sftp/protocol/05/base.rb, line 35 def open(path, flags, options) flags = normalize_open_flags(flags) sftp_flags, desired_access = if flags & (IO::WRONLY | IO::RDWR) != 0 open = if flags & (IO::CREAT | IO::EXCL) == (IO::CREAT | IO::EXCL) FV5::CREATE_NEW elsif flags & (IO::CREAT | IO::TRUNC) == (IO::CREAT | IO::TRUNC) FV5::CREATE_TRUNCATE elsif flags & IO::CREAT == IO::CREAT FV5::OPEN_OR_CREATE else FV5::OPEN_EXISTING end access = ACE::Mask::WRITE_DATA | ACE::Mask::WRITE_ATTRIBUTES access |= ACE::Mask::READ_DATA | ACE::Mask::READ_ATTRIBUTES if (flags & IO::RDWR) == IO::RDWR if flags & IO::APPEND == IO::APPEND open |= FV5::APPEND_DATA access |= ACE::Mask::APPEND_DATA end [open, access] else [FV5::OPEN_EXISTING, ACE::Mask::READ_DATA | ACE::Mask::READ_ATTRIBUTES] end attributes = attribute_factory.new(options) send_request(FXP_OPEN, :string, path, :long, desired_access, :long, sftp_flags, :raw, attributes.to_s) end
Sends a FXP_RENAME packet to the server to request that the file or
directory with the given name
(must be a full path) be changed
to new_name
(which must also be a path). The
flags
parameter must be either nil
or 0 (the
default), or some combination of the Net::SFTP::Constants::RenameFlags
constants.
# File lib/net/sftp/protocol/05/base.rb, line 25 def rename(name, new_name, flags=nil) send_request(FXP_RENAME, :string, name, :string, new_name, :long, flags || 0) end
Returns the protocol version implemented by this driver. (5, in this case)
# File lib/net/sftp/protocol/05/base.rb, line 16 def version 5 end