Files
goose/crates/goose-server/src/error.rs
Bradley Axen 1c9a7c0b05 feat: V1.0 (#734)
Co-authored-by: Michael Neale <michael.neale@gmail.com>
Co-authored-by: Wendy Tang <wendytang@squareup.com>
Co-authored-by: Jarrod Sibbison <72240382+jsibbison-square@users.noreply.github.com>
Co-authored-by: Alex Hancock <alex.hancock@example.com>
Co-authored-by: Alex Hancock <alexhancock@block.xyz>
Co-authored-by: Lifei Zhou <lifei@squareup.com>
Co-authored-by: Wes <141185334+wesrblock@users.noreply.github.com>
Co-authored-by: Max Novich <maksymstepanenko1990@gmail.com>
Co-authored-by: Zaki Ali <zaki@squareup.com>
Co-authored-by: Salman Mohammed <smohammed@squareup.com>
Co-authored-by: Kalvin C <kalvinnchau@users.noreply.github.com>
Co-authored-by: Alec Thomas <alec@swapoff.org>
Co-authored-by: lily-de <119957291+lily-de@users.noreply.github.com>
Co-authored-by: kalvinnchau <kalvin@block.xyz>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: Rizel Scarlett <rizel@squareup.com>
Co-authored-by: bwrage <bwrage@squareup.com>
Co-authored-by: Kalvin Chau <kalvin@squareup.com>
Co-authored-by: Alice Hau <110418948+ahau-square@users.noreply.github.com>
Co-authored-by: Alistair Gray <ajgray@stripe.com>
Co-authored-by: Nahiyan Khan <nahiyan.khan@gmail.com>
Co-authored-by: Alex Hancock <alexhancock@squareup.com>
Co-authored-by: Nahiyan Khan <nahiyan@squareup.com>
Co-authored-by: marcelle <1852848+laanak08@users.noreply.github.com>
Co-authored-by: Yingjie He <yingjiehe@block.xyz>
Co-authored-by: Yingjie He <yingjiehe@squareup.com>
Co-authored-by: Lily Delalande <ldelalande@block.xyz>
Co-authored-by: Adewale Abati <acekyd01@gmail.com>
Co-authored-by: Ebony Louis <ebony774@gmail.com>
Co-authored-by: Angie Jones <jones.angie@gmail.com>
Co-authored-by: Ebony Louis <55366651+EbonyLouis@users.noreply.github.com>
2025-01-24 13:04:43 -08:00

41 lines
1.2 KiB
Rust

use thiserror::Error;
#[derive(Error, Debug)]
pub enum ConfigError {
#[error("Missing required environment variable: {env_var}")]
MissingEnvVar { env_var: String },
#[error("Configuration error: {0}")]
Other(#[from] config::ConfigError),
}
// Helper function to format environment variable names
pub(crate) fn to_env_var(field_path: &str) -> String {
// Handle nested fields by converting dots to double underscores
// If the field is in the provider object, we need to prefix it appropriately
let normalized_path = if field_path == "type" {
"provider.type".to_string()
} else if field_path.starts_with("provider.") {
field_path.to_string()
} else {
format!("provider.{}", field_path)
};
format!(
"GOOSE_{}",
normalized_path.replace('.', "__").to_uppercase()
)
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_env_var_conversion() {
assert_eq!(to_env_var("type"), "GOOSE_PROVIDER__TYPE");
assert_eq!(to_env_var("api_key"), "GOOSE_PROVIDER__API_KEY");
assert_eq!(to_env_var("provider.host"), "GOOSE_PROVIDER__HOST");
assert_eq!(to_env_var("provider.api_key"), "GOOSE_PROVIDER__API_KEY");
}
}