Enum ssh_packet::userauth::Method

source ·
pub enum Method {
    None,
    Publickey {
        algorithm: Bytes,
        blob: Bytes,
        signature: Option<Bytes>,
    },
    Password {
        password: StringUtf8,
        new: Option<StringUtf8>,
    },
    Hostbased {
        algorithm: Bytes,
        host_key: Bytes,
        client_fqdn: StringAscii,
        username: StringUtf8,
        signature: Bytes,
    },
    KeyboardInteractive {
        language: StringAscii,
        submethods: StringUtf8,
    },
}
Expand description

The authentication method in the SSH_MSG_USERAUTH_REQUEST message.

Variants§

§

None

Authenticate using the none method, as defined in RFC4252 section 5.2.

§

Publickey

Authenticate using the publickey method, as defined in RFC4252 section 7.

Fields

§algorithm: Bytes

Public key algorithm’s name.

§blob: Bytes

Public key blob.

§signature: Option<Bytes>

The optional signature of the authentication packet, signed with the according private key.

§

Password

Authenticate using the password method, as defined in RFC4252 section 8.

Fields

§password: StringUtf8

Plaintext password.

§new: Option<StringUtf8>

In the case of a the receival of a PasswdChangereq, the new password to be set in place of the old one.

§

Hostbased

Authenticate using the hostbased method, as defined in RFC4252 section 9.

Fields

§algorithm: Bytes

Public key algorithm for the host key.

§host_key: Bytes

Public host key and certificates for client host.

§client_fqdn: StringAscii

Client host name expressed as the FQDN.

§username: StringUtf8

User name on the client host.

§signature: Bytes

The signature of the authentication packet.

§

KeyboardInteractive

Authenticate using the keyboard-interactive method, as defined in RFC4256 section 3.1.

Fields

§language: StringAscii

Language tag.

§submethods: StringUtf8

A hint for the prefered interactive submethod.

Implementations§

source§

impl Method

source

pub const NONE: &'static str = "none"

The SSH none authentication method.

source

pub const PUBLICKEY: &'static str = "publickey"

The SSH publickey authentication method.

source

pub const PASSWORD: &'static str = "password"

The SSH password authentication method.

source

pub const HOSTBASED: &'static str = "hostbased"

The SSH hostbased authentication method.

source

pub const KEYBOARD_INTERACTIVE: &'static str = "keyboard-interactive"

The SSH keyboard-interactive authentication method.

source

pub fn as_str(&self) -> &'static str

Get the Method’s SSH identifier.

Trait Implementations§

source§

impl BinRead for Method

§

type Args<'__binrw_generated_args_lifetime> = (&'__binrw_generated_args_lifetime str,)

The type used for the args parameter of read_args() and read_options(). Read more
source§

fn read_options<R: Read + Seek>( __binrw_generated_var_reader: &mut R, __binrw_generated_var_endian: Endian, __binrw_generated_var_arguments: Self::Args<'_>, ) -> BinResult<Self>

Read Self from the reader using the given Endian and arguments. Read more
source§

fn read_be<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments and assuming big-endian byte order. Read more
source§

fn read_le<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments and assuming little-endian byte order. Read more
source§

fn read_ne<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read T from the reader assuming native-endian byte order. Read more
source§

fn read_be_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read Self from the reader, assuming big-endian byte order, using the given arguments. Read more
source§

fn read_le_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read Self from the reader, assuming little-endian byte order, using the given arguments. Read more
source§

fn read_ne_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read T from the reader, assuming native-endian byte order, using the given arguments. Read more
source§

impl BinWrite for Method

§

type Args<'__binrw_generated_args_lifetime> = ()

The type used for the args parameter of write_args() and write_options(). Read more
source§

fn write_options<W: Write + Seek>( &self, __binrw_generated_var_writer: &mut W, __binrw_generated_var_endian: Endian, __binrw_generated_var_arguments: Self::Args<'_>, ) -> BinResult<()>

Write Self to the writer using the given Endian and arguments. Read more
source§

fn write_be<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self::Args<'a>: for<'a> Required,

Write Self to the writer assuming big-endian byte order. Read more
source§

fn write_le<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self::Args<'a>: for<'a> Required,

Write Self to the writer assuming little-endian byte order. Read more
source§

fn write_be_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek,

Write Self to the writer, assuming big-endian byte order, using the given arguments. Read more
source§

fn write_le_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek,

Write Self to the writer, assuming little-endian byte order, using the given arguments. Read more
source§

impl Clone for Method

source§

fn clone(&self) -> Method

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Method

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Method

§

impl RefUnwindSafe for Method

§

impl Send for Method

§

impl Sync for Method

§

impl Unpin for Method

§

impl UnwindSafe for Method

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.