EnvHandler

Struct EnvHandler 

Source
pub struct EnvHandler<'a> { /* private fields */ }
Expand description

A handler for retrieving values from environment variables.

This struct is responsible for handling requests by checking for the existence of an environment variable corresponding to the provided key. If the environment variable is not found, it delegates the request to the next handler (if provided).

§Examples

use cor_args::{EnvHandler, Handler};

// Create a new EnvHandler specifying a prefix for environment variables
let handler = EnvHandler::new().prefix("MYAPP_");

// Add a fallback handler
//let handler = handler.next(some_other_handler.into());

// Handle a configuration request matching `MYAPP_some_key`
let value = handler.handle_request("some_key");

Implementations§

Source§

impl<'a> EnvHandler<'a>

Source

pub fn new() -> Self

Creates a new EnvHandler.

§Arguments
  • prefix - An optional prefix to which requests will prepend when handle_request() is executed.IfNone`, an empty string is assigned.
§Examples
use cor_args::EnvHandler;

let handler = EnvHandler::new();
Source

pub fn next(self, handler: Box<dyn Handler>) -> Self

Source

pub fn prefix<S>(self, prefix: S) -> Self
where S: Into<Cow<'a, str>>,

Trait Implementations§

Source§

impl<'a> Handler for EnvHandler<'a>

Source§

fn handle_request(&self, key: &str) -> Option<String>

Retrieves a value for the specified key from the environment variables.

If the environment variable corresponding to the key is not found, and if a next handler is provided, it delegates the request to the next handler. If there’s no next handler or if the key is not found both in the environment and the next handler, it returns None.

§Arguments
  • key - The key for which the value needs to be retrieved from environment variables.
§Returns

An Option containing the value associated with the key, or None if the key is not found.

Source§

impl<'a> Into<Box<dyn Handler + 'a>> for EnvHandler<'a>

Source§

fn into(self) -> Box<dyn Handler + 'a>

Converts this type into the (usually inferred) input type.

Auto Trait Implementations§

§

impl<'a> Freeze for EnvHandler<'a>

§

impl<'a> !RefUnwindSafe for EnvHandler<'a>

§

impl<'a> !Send for EnvHandler<'a>

§

impl<'a> !Sync for EnvHandler<'a>

§

impl<'a> Unpin for EnvHandler<'a>

§

impl<'a> !UnwindSafe for EnvHandler<'a>

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