struct KeyValidator {
host: String,
port: u16,
entries: Vec<Entry>,
}
Expand description
Validator for a host’s SSH keys and a list of known_hosts
entries.
Tracks a host
and its port
, as well as a list of entries
in the SSH known_hosts
file
format.
Fields§
§host: String
§port: u16
§entries: Vec<Entry>
Trait Implementations§
Source§impl Handler for KeyValidator
impl Handler for KeyValidator
Source§async fn check_server_key(
&mut self,
server_public_key: &PublicKey,
) -> Result<bool, Error>
async fn check_server_key( &mut self, server_public_key: &PublicKey, ) -> Result<bool, Error>
Checks whether a set of server details can be found in SSH known_hosts
data.
Based on a host
and its port
, this function evaluates whether a supplied key
is part
of a list of entries
in the SSH known_hosts file format. Returns true
, if the
combination of key
, host
and port
matches an entry in the list of entries
and that
entry is not a CA key or a revoked key. Returns false
in all other cases.
type Error = Error
Called when the server sends us an authentication banner. This
is usually meant to be shown to the user, see
RFC4252 for
more details.
§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).
§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.
§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.
§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.
§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.
§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.
§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
§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
§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.§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.
§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.
§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.
§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.
§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.§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.§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.
§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.
§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.
§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.§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 KeyValidator
impl RefUnwindSafe for KeyValidator
impl Send for KeyValidator
impl Sync for KeyValidator
impl Unpin for KeyValidator
impl UnwindSafe for KeyValidator
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