Auto-update: Thu Aug 8 18:07:02 PDT 2024
This commit is contained in:
parent
daa2e9f117
commit
d7f499b7e4
1 changed files with 19 additions and 22 deletions
|
@ -99,6 +99,7 @@ class Configuration(BaseModel):
|
|||
config_data = yaml.safe_load(file)
|
||||
|
||||
debug(f"Loaded configuration data from {yaml_path}")
|
||||
secrets_data = {}
|
||||
if secrets_path:
|
||||
with secrets_path.open('r') as file:
|
||||
secrets_data = yaml.safe_load(file)
|
||||
|
@ -120,7 +121,7 @@ class Configuration(BaseModel):
|
|||
load_dotenv()
|
||||
instance = cls.create_dynamic_model(**config_data)
|
||||
instance._dir_config = dir_config or instance
|
||||
resolved_data = instance.resolve_placeholders(config_data)
|
||||
resolved_data = instance.resolve_placeholders(config_data, secrets_data)
|
||||
instance = cls.create_dynamic_model(**resolved_data)
|
||||
instance._dir_config = dir_config or instance
|
||||
return instance
|
||||
|
@ -129,7 +130,6 @@ class Configuration(BaseModel):
|
|||
err(f"Error loading configuration: {str(e)}")
|
||||
raise
|
||||
|
||||
|
||||
@classmethod
|
||||
def _resolve_path(cls, path: Union[str, Path], default_dir: str) -> Path:
|
||||
base_path = Path(__file__).parent.parent
|
||||
|
@ -140,10 +140,9 @@ class Configuration(BaseModel):
|
|||
path = base_path / path
|
||||
return path
|
||||
|
||||
@classmethod
|
||||
def resolve_placeholders(self, data: Any) -> Any:
|
||||
def resolve_placeholders(self, data: Any, secrets_data: Dict[str, Any]) -> Any:
|
||||
if isinstance(data, dict):
|
||||
resolved_data = {k: self.resolve_placeholders(v) for k, v in data.items()}
|
||||
resolved_data = {k: self.resolve_placeholders(v, secrets_data) for k, v in data.items()}
|
||||
home_dir = Path(resolved_data.get('HOME', self.HOME)).expanduser()
|
||||
base_dir = Path(__file__).parent.parent
|
||||
data_dir = base_dir / "data"
|
||||
|
@ -152,14 +151,13 @@ class Configuration(BaseModel):
|
|||
resolved_data['DATA'] = str(data_dir)
|
||||
return resolved_data
|
||||
elif isinstance(data, list):
|
||||
return [self.resolve_placeholders(v) for v in data]
|
||||
return [self.resolve_placeholders(v, secrets_data) for v in data]
|
||||
elif isinstance(data, str):
|
||||
return self.resolve_string_placeholders(data)
|
||||
return self.resolve_string_placeholders(data, secrets_data, self.HOME)
|
||||
else:
|
||||
return data
|
||||
|
||||
@classmethod
|
||||
def resolve_string_placeholders(cls, value: str, secrets_data: Dict[str, Any], home_dir: Path) -> Any:
|
||||
def resolve_string_placeholders(self, value: str, secrets_data: Dict[str, Any], home_dir: Path) -> Any:
|
||||
pattern = r'\{\{\s*([^}]+)\s*\}\}'
|
||||
matches = re.findall(pattern, value)
|
||||
|
||||
|
@ -207,7 +205,6 @@ class Configuration(BaseModel):
|
|||
|
||||
|
||||
|
||||
|
||||
class DirConfig(BaseModel):
|
||||
HOME: Path = Path.home()
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue