import os from typing import Any, Callable, List, Optional, Type, TypeVar, Union from inference.core.exceptions import InvalidEnvironmentVariableError T = TypeVar("T") def safe_env_to_type( variable_name: str, default_value: Optional[T] = None, type_constructor: Optional[Union[Type[T], Callable[[str], T]]] = None, ) -> Optional[T]: """ Converts env variable to specified type, but only if variable is set - otherwise default is returned. If `type_constructor` is not given - value of type str will be returned. """ if variable_name not in os.environ: return default_value variable_value = os.environ[variable_name] if type_constructor is None: return variable_value return type_constructor(variable_value) def str2bool(value: Any) -> bool: """ Converts an environment variable to a boolean value. Args: value (str or bool): The environment variable value to be converted. Returns: bool: The converted boolean value. Raises: InvalidEnvironmentVariableError: If the value is not 'true', 'false', or a boolean. """ if isinstance(value, bool): return value if not issubclass(type(value), str): raise InvalidEnvironmentVariableError( f"Expected a boolean environment variable (true or false) but got '{value}'" ) if value.lower() == "true": return True elif value.lower() == "false": return False else: raise InvalidEnvironmentVariableError( f"Expected a boolean environment variable (true or false) but got '{value}'" ) def safe_split_value(value: Optional[str], delimiter: str = ",") -> Optional[List[str]]: """ Splits a separated environment variable into a list. Args: value (str): The environment variable value to be split. delimiter(str): Delimiter to be used Returns: list or None: The split values as a list, or None if the input is None. """ if value is None: return None else: return value.split(delimiter)