class HrrRbSftp::Protocol::Version3::Packets::SSH_FXP_MKDIR

This class implements SFTP protocol version 3 SSH_FXP_MKDIR packet type, format, and responder.

Constants

FORMAT

Represents SSH_FXP_MKDIR packet format.

Public Instance Methods

respond_to(request) click to toggle source

Responds to SSH_FXP_MKDIR request.

@param request [Hash{Symbol=>Object}] SSH_FXP_MKDIR request represented in Hash. @return [Hash{Symbol=>Object}] Response represented in Hash. Its type is SSH_FXP_STATUS.

# File lib/hrr_rb_sftp/protocol/version3/packets/014_ssh_fxp_mkdir.rb, line 27
def respond_to request
  begin
    args = [request[:"path"]]
    if request[:"attrs"].has_key?(:"permissions")
      args.push request[:"attrs"][:"permissions"]
    end
    log_debug { "Dir.mkdir(#{args.map(&:inspect).join(", ")})" }
    Dir.mkdir(*args)
    {
      :"type"          => Packets::SSH_FXP_STATUS::TYPE,
      :"request-id"    => request[:"request-id"],
      :"code"          => Packets::SSH_FXP_STATUS::SSH_FX_OK,
      :"error message" => "Success",
      :"language tag"  => "",
    }
  rescue Errno::EACCES => e
    log_debug { e.message }
    {
      :"type"          => Packets::SSH_FXP_STATUS::TYPE,
      :"request-id"    => request[:"request-id"],
      :"code"          => Packets::SSH_FXP_STATUS::SSH_FX_PERMISSION_DENIED,
      :"error message" => "Permission denied",
      :"language tag"  => "",
    }
  rescue Errno::EEXIST => e
    log_debug { e.message }
    {
      :"type"          => Packets::SSH_FXP_STATUS::TYPE,
      :"request-id"    => request[:"request-id"],
      :"code"          => Packets::SSH_FXP_STATUS::SSH_FX_FAILURE,
      :"error message" => "File exists",
      :"language tag"  => "",
    }
  rescue => e
    log_error { [e.backtrace[0], ": ", e.message, " (", e.class.to_s, ")\n\t", e.backtrace[1..-1].join("\n\t")].join }
    {
      :"type"          => Packets::SSH_FXP_STATUS::TYPE,
      :"request-id"    => request[:"request-id"],
      :"code"          => Packets::SSH_FXP_STATUS::SSH_FX_FAILURE,
      :"error message" => e.message,
      :"language tag"  => "",
    }
  end
end