1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
use std::env;

use dotenv::dotenv;
use secrecy::{ExposeSecret, Secret};

use crate::AuthError;

pub fn cred_from_env(env_key: String) -> Result<Secret<String>, AuthError> {
    dotenv().ok();

    let pk = env::var(env_key)
        .map_err(|_| AuthError::NoPublicKey)
        .unwrap();

    Ok(Secret::new(pk))
}

pub fn expose_secret(secret: Secret<String>) -> String {
    secret.expose_secret().to_owned()
}