Skip to main content

Config

Struct Config 

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

Configuration management for aster.

This module provides a flexible configuration system that supports:

  • Dynamic configuration keys
  • Multiple value types through serde deserialization
  • Environment variable overrides
  • YAML-based configuration file storage
  • Hot reloading of configuration changes
  • Secure secret storage in system keyring

Configuration values are loaded with the following precedence:

  1. Environment variables (exact key match)
  2. Configuration file (~/.config/aster/config.yaml by default)

Secrets are loaded with the following precedence:

  1. Environment variables (exact key match)
  2. System keyring (which can be disabled with ASTER_DISABLE_KEYRING)
  3. If the keyring is disabled, secrets are stored in a secrets file (~/.config/aster/secrets.yaml by default)

§Examples

use aster::config::Config;
use serde::Deserialize;

// Get a string value
let config = Config::global();
let api_key: String = config.get_param("OPENAI_API_KEY").unwrap();

// Get a complex type
#[derive(Deserialize)]
struct ServerConfig {
    host: String,
    port: u16,
}

let server_config: ServerConfig = config.get_param("server").unwrap();

§Naming Convention

we recommend snake_case for keys, and will convert to UPPERCASE when checking for environment overrides. e.g. openai_api_key will check for an environment variable OPENAI_API_KEY

For aster-specific configuration, consider prefixing with “aster_” to avoid conflicts.

Implementations§

Source§

impl Config

Source

pub fn global() -> &'static Config

Get the global configuration instance.

This will initialize the configuration with the default path (~/.config/aster/config.yaml) if it hasn’t been initialized yet.

Source

pub fn new<P: AsRef<Path>>( config_path: P, service: &str, ) -> Result<Self, ConfigError>

Create a new configuration instance with custom paths

This is primarily useful for testing or for applications that need to manage multiple configuration files.

Source

pub fn new_with_file_secrets<P1: AsRef<Path>, P2: AsRef<Path>>( config_path: P1, secrets_path: P2, ) -> Result<Self, ConfigError>

Create a new configuration instance with custom paths

This is primarily useful for testing or for applications that need to manage multiple configuration files.

Source

pub fn exists(&self) -> bool

Source

pub fn clear(&self) -> Result<(), ConfigError>

Source

pub fn path(&self) -> String

Source

pub fn all_values(&self) -> Result<HashMap<String, Value>, ConfigError>

Source

pub fn initialize_if_empty(&self, values: Mapping) -> Result<(), ConfigError>

Source

pub fn all_secrets(&self) -> Result<HashMap<String, Value>, ConfigError>

Source

pub fn get(&self, key: &str, is_secret: bool) -> Result<Value, ConfigError>

Source

pub fn set<V>( &self, key: &str, value: &V, is_secret: bool, ) -> Result<(), ConfigError>
where V: Serialize,

Source

pub fn get_param<T: for<'de> Deserialize<'de>>( &self, key: &str, ) -> Result<T, ConfigError>

Get a configuration value (non-secret).

This will attempt to get the value from:

  1. Environment variable with the exact key name
  2. Configuration file

The value will be deserialized into the requested type. This works with both simple types (String, i32, etc.) and complex types that implement serde::Deserialize.

§Errors

Returns a ConfigError if:

  • The key doesn’t exist in either environment or config file
  • The value cannot be deserialized into the requested type
  • There is an error reading the config file
Source

pub fn set_param<V: Serialize>( &self, key: &str, value: V, ) -> Result<(), ConfigError>

Set a configuration value in the config file (non-secret).

This will immediately write the value to the config file. The value can be any type that can be serialized to JSON/YAML.

Note that this does not affect environment variables - those can only be set through the system environment.

§Errors

Returns a ConfigError if:

  • There is an error reading or writing the config file
  • There is an error serializing the value
Source

pub fn delete(&self, key: &str) -> Result<(), ConfigError>

Delete a configuration value in the config file.

This will immediately write the value to the config file. The value can be any type that can be serialized to JSON/YAML.

Note that this does not affect environment variables - those can only be set through the system environment.

§Errors

Returns a ConfigError if:

  • There is an error reading or writing the config file
  • There is an error serializing the value
Source

pub fn get_secret<T: for<'de> Deserialize<'de>>( &self, key: &str, ) -> Result<T, ConfigError>

Get a secret value.

This will attempt to get the value from:

  1. Environment variable with the exact key name
  2. System keyring

The value will be deserialized into the requested type. This works with both simple types (String, i32, etc.) and complex types that implement serde::Deserialize.

§Errors

Returns a ConfigError if:

  • The key doesn’t exist in either environment or keyring
  • The value cannot be deserialized into the requested type
  • There is an error accessing the keyring
Source

pub fn get_secrets( &self, primary: &str, maybe_secret: &[&str], ) -> Result<HashMap<String, String>, ConfigError>

Get secrets. If primary is in env, use env for all keys. Otherwise use secret storage.

Source

pub fn set_secret<V>(&self, key: &str, value: &V) -> Result<(), ConfigError>
where V: Serialize,

Set a secret value in the system keyring.

This will store the value in a single JSON object in the system keyring, alongside any other secrets. The value can be any type that can be serialized to JSON.

Note that this does not affect environment variables - those can only be set through the system environment.

§Errors

Returns a ConfigError if:

  • There is an error accessing the keyring
  • There is an error serializing the value
Source

pub fn delete_secret(&self, key: &str) -> Result<(), ConfigError>

Delete a secret from the system keyring.

This will remove the specified key from the JSON object in the system keyring. Other secrets will remain unchanged.

§Errors

Returns a ConfigError if:

  • There is an error accessing the keyring
  • There is an error serializing the remaining values
Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Source§

impl Config

Trait Implementations§

Source§

impl Default for Config

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

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> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FutureExt for T

Source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
Source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<Unshared, Shared> IntoShared<Shared> for Unshared
where Shared: FromUnshared<Unshared>,

Source§

fn into_shared(self) -> Shared

Creates a shared type from an unshared type.
Source§

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

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

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

impl<T> ErasedDestructor for T
where T: 'static,