Struct Config

Source
pub struct Config { /* private fields */ }
Expand description

A context for resolving configuration values. Holds a combination of environment and token expansion state, as well as the set of configs that should be consulted.

Implementations§

Source§

impl Config

Source

pub fn new() -> Self

Create a new context without any config files loaded

Source

pub fn assign_environment(&mut self, env: ConfigMap)

Assign a fake environment map, useful for testing. The environment is used to expand certain values from the config.

Source

pub fn assign_tokens(&mut self, tokens: ConfigMap)

Assigns token names and expansions for use with a number of options. The names and expansions are specified by man 5 ssh_config

Source

pub fn set_option<K: AsRef<str>, V: AsRef<str>>(&mut self, key: K, value: V)

Assign the value for an option. This is logically equivalent to the user specifying command line options to override config values. These values take precedence over any values found in config files.

Source

pub fn add_config_string(&mut self, config_string: &str)

Parse config_string as if it were the contents of an ssh_config file, and add that to the list of configs.

Source

pub fn add_config_file<P: AsRef<Path>>(&mut self, path: P)

Open path, read its contents and parse it as an ssh_config file, adding that to the list of configs

Source

pub fn add_default_config_files(&mut self)

Convenience method for adding the ~/.ssh/config and system-wide /etc/ssh/config files to the list of configs

Source

pub fn for_host<H: AsRef<str>>(&self, host: H) -> ConfigMap

Resolve the configuration for a given host. The returned map will expand environment and tokens for options where that is specified. Note that in some configurations, the config should be parsed once to resolve the main configuration, and then based on some options (such as CanonicalHostname), the tokens should be updated and the config parsed a second time in order for value expansion to have the same results as ssh.

Trait Implementations§

Source§

impl Clone for Config

Source§

fn clone(&self) -> Config

Returns a duplicate 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 Config

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Config

§

impl RefUnwindSafe for Config

§

impl Send for Config

§

impl Sync for Config

§

impl Unpin for Config

§

impl UnwindSafe for Config

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§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> ToOwned for T
where T: Clone,

Source§

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>,

Source§

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>,

Source§

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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more