pub struct NoCheckHandler;Expand description
A handler that does NOT check the server’s public key.
This should NOT be used unless you are certain that the SSH server is trusted and you are aware of the security implications of not verifying the server’s public key, particularly the risk of man-in-the-middle (MITM) attacks.
This should only be used with public key authentication, as it provides some protection against MITM attacks.
Trait Implementations§
Source§impl Handler for NoCheckHandler
impl Handler for NoCheckHandler
type Error = Error
Source§async fn check_server_key(
&mut self,
_server_public_key: &PublicKey,
) -> Result<bool, Self::Error>
async fn check_server_key( &mut self, _server_public_key: &PublicKey, ) -> Result<bool, Self::Error>
Called to check the server’s public key. This is a very important
step to help prevent man-in-the-middle attacks. The default
implementation rejects all keys.
Called when the server sends us an authentication banner. This
is usually meant to be shown to the user, see
RFC4252 for
more details.
Source§fn channel_open_confirmation(
&mut self,
id: ChannelId,
max_packet_size: u32,
window_size: u32,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn channel_open_confirmation( &mut self, id: ChannelId, max_packet_size: u32, window_size: u32, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server confirmed our request to open a
channel. A channel can only be written to after receiving this
message (this library panics otherwise).
Source§fn channel_success(
&mut self,
channel: ChannelId,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn channel_success( &mut self, channel: ChannelId, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server signals success.
Source§fn channel_failure(
&mut self,
channel: ChannelId,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn channel_failure( &mut self, channel: ChannelId, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server signals failure.
Source§fn channel_close(
&mut self,
channel: ChannelId,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn channel_close( &mut self, channel: ChannelId, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server closes a channel.
Source§fn channel_eof(
&mut self,
channel: ChannelId,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn channel_eof( &mut self, channel: ChannelId, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server sends EOF to a channel.
Source§fn channel_open_failure(
&mut self,
channel: ChannelId,
reason: ChannelOpenFailure,
description: &str,
language: &str,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn channel_open_failure( &mut self, channel: ChannelId, reason: ChannelOpenFailure, description: &str, language: &str, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server rejected our request to open a channel.
Source§fn server_channel_open_forwarded_tcpip(
&mut self,
channel: Channel<Msg>,
connected_address: &str,
connected_port: u32,
originator_address: &str,
originator_port: u32,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn server_channel_open_forwarded_tcpip( &mut self, channel: Channel<Msg>, connected_address: &str, connected_port: u32, originator_address: &str, originator_port: u32, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server opens a channel for a new remote port forwarding connection
fn server_channel_open_forwarded_streamlocal( &mut self, channel: Channel<Msg>, socket_path: &str, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Source§fn server_channel_open_agent_forward(
&mut self,
channel: Channel<Msg>,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn server_channel_open_agent_forward( &mut self, channel: Channel<Msg>, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server opens an agent forwarding channel
Source§fn should_accept_unknown_server_channel(
&mut self,
id: ChannelId,
channel_type: &str,
) -> impl Future<Output = bool> + Send
fn should_accept_unknown_server_channel( &mut self, id: ChannelId, channel_type: &str, ) -> impl Future<Output = bool> + Send
Called when the server attempts to open a channel of unknown type. It may return
true,
if the channel of unknown type should be accepted. In this case,
Handler::server_channel_open_unknown will be called soon after. If it returns false,
the channel will not be created and a rejection message will be sent to the server.Source§fn server_channel_open_unknown(
&mut self,
channel: Channel<Msg>,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn server_channel_open_unknown( &mut self, channel: Channel<Msg>, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server opens an unknown channel.
Source§fn server_channel_open_session(
&mut self,
channel: Channel<Msg>,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn server_channel_open_session( &mut self, channel: Channel<Msg>, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server opens a session channel.
Source§fn server_channel_open_direct_tcpip(
&mut self,
channel: Channel<Msg>,
host_to_connect: &str,
port_to_connect: u32,
originator_address: &str,
originator_port: u32,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn server_channel_open_direct_tcpip( &mut self, channel: Channel<Msg>, host_to_connect: &str, port_to_connect: u32, originator_address: &str, originator_port: u32, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server opens a direct tcp/ip channel.
Source§fn server_channel_open_x11(
&mut self,
channel: Channel<Msg>,
originator_address: &str,
originator_port: u32,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn server_channel_open_x11( &mut self, channel: Channel<Msg>, originator_address: &str, originator_port: u32, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server opens an X11 channel.
Source§fn data(
&mut self,
channel: ChannelId,
data: &[u8],
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn data( &mut self, channel: ChannelId, data: &[u8], session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server sends us data. The
extended_code
parameter is a stream identifier, None is usually the
standard output, and Some(1) is the standard error. See
RFC4254.Source§fn extended_data(
&mut self,
channel: ChannelId,
ext: u32,
data: &[u8],
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn extended_data( &mut self, channel: ChannelId, ext: u32, data: &[u8], session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the server sends us data. The
extended_code
parameter is a stream identifier, None is usually the
standard output, and Some(1) is the standard error. See
RFC4254.Source§fn xon_xoff(
&mut self,
channel: ChannelId,
client_can_do: bool,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn xon_xoff( &mut self, channel: ChannelId, client_can_do: bool, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
The server informs this client of whether the client may
perform control-S/control-Q flow control. See
RFC4254.
Source§fn exit_status(
&mut self,
channel: ChannelId,
exit_status: u32,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn exit_status( &mut self, channel: ChannelId, exit_status: u32, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
The remote process has exited, with the given exit status.
Source§fn exit_signal(
&mut self,
channel: ChannelId,
signal_name: Sig,
core_dumped: bool,
error_message: &str,
lang_tag: &str,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn exit_signal( &mut self, channel: ChannelId, signal_name: Sig, core_dumped: bool, error_message: &str, lang_tag: &str, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
The remote process exited upon receiving a signal.
Source§fn window_adjusted(
&mut self,
channel: ChannelId,
new_size: u32,
session: &mut Session,
) -> impl Future<Output = Result<(), Self::Error>> + Send
fn window_adjusted( &mut self, channel: ChannelId, new_size: u32, session: &mut Session, ) -> impl Future<Output = Result<(), Self::Error>> + Send
Called when the network window is adjusted, meaning that we
can send more bytes. This is useful if this client wants to
send huge amounts of data, for instance if we have called
Session::data before, and it returned less than the
full amount of data.Source§fn adjust_window(&mut self, channel: ChannelId, window: u32) -> u32
fn adjust_window(&mut self, channel: ChannelId, window: u32) -> u32
Called when this client adjusts the network window. Return the
next target window and maximum packet size.
Auto Trait Implementations§
impl Freeze for NoCheckHandler
impl RefUnwindSafe for NoCheckHandler
impl Send for NoCheckHandler
impl Sync for NoCheckHandler
impl Unpin for NoCheckHandler
impl UnwindSafe for NoCheckHandler
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more