1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
use std::env;

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

use crate::AuthError;

/// Helper function that looks for Secret Key from your `.env` file and returns a `Secret<String>`.
/// 
/// # Example
/// ```rust
/// let key = cred_from_env("SECRET_KEY".to_string()).unwrap();
/// 
/// let builder = PaymentBuilder::init_payment(
///     "test@example.com".to_string(),
///     100.0,
///     key,
/// );
/// 
/// Payment(builder).send();
/// 
/// ```
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))
}

/// Helper for unmasking `Secret` wrapper
pub fn expose_secret(secret: Secret<String>) -> String {
    secret.expose_secret().to_owned()
}