This commit is contained in:
		
							parent
							
								
									6a57d91b7e
								
							
						
					
					
						commit
						6f5e817011
					
				| @ -40,10 +40,14 @@ ENV PYTHONDONTWRITEBYTECODE=1 \ | |||||||
| # Copy the configuration directory first. | # Copy the configuration directory first. | ||||||
| # If only code changes, this layer remains cached. | # If only code changes, this layer remains cached. | ||||||
| COPY config ./config | COPY config ./config | ||||||
|  | COPY llm ./llm | ||||||
|  | COPY app ./app | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| # Copy your application source code. | # Copy your application source code. | ||||||
| COPY main.py . | COPY main.py . | ||||||
| COPY config.py . | COPY config.py . | ||||||
|  | COPY shared_store.py . | ||||||
| 
 | 
 | ||||||
| # Expose the port your application listens on. | # Expose the port your application listens on. | ||||||
| EXPOSE 8000 | EXPOSE 8000 | ||||||
|  | |||||||
							
								
								
									
										65
									
								
								config.py
									
									
									
									
									
								
							
							
						
						
									
										65
									
								
								config.py
									
									
									
									
									
								
							| @ -69,29 +69,16 @@ class ProcessorConfig(BaseSettings): | |||||||
| class Settings: | class Settings: | ||||||
|     def __init__(self): |     def __init__(self): | ||||||
|         try: |         try: | ||||||
|             # Load configuration from YAML file |             # Load settings from YAML file as a fallback | ||||||
|             yaml_config = self._load_yaml_config() |             yaml_config = self._load_yaml_config() | ||||||
|              |              | ||||||
|             # Initialize configurations |             # Load settings from environment and .env file first | ||||||
|             llm_config_data = yaml_config.get('llm', {}) |             self.llm = LLMConfig() | ||||||
|              |             self.processor = ProcessorConfig() | ||||||
|             # Extract and flatten nested LLM configurations |             self.langfuse = LangfuseConfig() | ||||||
|             mode = llm_config_data.get('mode', 'ollama') |  | ||||||
|             openai_settings = llm_config_data.get('openai') or {} |  | ||||||
|             ollama_settings = llm_config_data.get('ollama') or {} |  | ||||||
|             gemini_settings = llm_config_data.get('gemini') or {} # New: Get Gemini settings |  | ||||||
| 
 | 
 | ||||||
|             # Combine all LLM settings, prioritizing top-level 'mode' |             # Apply YAML configuration for any values not set by the environment | ||||||
|             combined_llm_settings = { |             self._apply_yaml_fallback(yaml_config) | ||||||
|                 'mode': mode, |  | ||||||
|                 **{f'openai_{k}': v for k, v in openai_settings.items()}, |  | ||||||
|                 **{f'ollama_{k}': v for k, v in ollama_settings.items()}, |  | ||||||
|                 **{f'gemini_{k}': v for k, v in gemini_settings.items()} # New: Add Gemini settings |  | ||||||
|             } |  | ||||||
|              |  | ||||||
|             self.llm = LLMConfig(**combined_llm_settings) |  | ||||||
|             self.processor = ProcessorConfig(**yaml_config.get('processor', {})) |  | ||||||
|             self.langfuse = LangfuseConfig(**yaml_config.get('langfuse', {})) |  | ||||||
| 
 | 
 | ||||||
|             # Initialize Langfuse client if enabled |             # Initialize Langfuse client if enabled | ||||||
|             self.langfuse_client: Optional[Langfuse] = None |             self.langfuse_client: Optional[Langfuse] = None | ||||||
| @ -111,6 +98,44 @@ class Settings: | |||||||
|             print(f"Configuration initialization failed: {e}") |             print(f"Configuration initialization failed: {e}") | ||||||
|             sys.exit(1) |             sys.exit(1) | ||||||
| 
 | 
 | ||||||
|  |     def _apply_yaml_fallback(self, yaml_config: dict): | ||||||
|  |         """Applies YAML config values as a fallback to settings not set by environment.""" | ||||||
|  |          | ||||||
|  |         # --- LLM Configuration --- | ||||||
|  |         llm_yaml_config = yaml_config.get('llm', {}) | ||||||
|  |         if llm_yaml_config: | ||||||
|  |             # Flatten nested YAML structure to match LLMConfig fields | ||||||
|  |             flat_llm_yaml = { | ||||||
|  |                 'mode': llm_yaml_config.get('mode'), | ||||||
|  |                 **{f'openai_{k}': v for k, v in (llm_yaml_config.get('openai') or {}).items()}, | ||||||
|  |                 **{f'ollama_{k}': v for k, v in (llm_yaml_config.get('ollama') or {}).items()}, | ||||||
|  |                 **{f'gemini_{k}': v for k, v in (llm_yaml_config.get('gemini') or {}).items()} | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             for field_name in self.llm.model_fields: | ||||||
|  |                 if field_name not in self.llm.model_fields_set: | ||||||
|  |                     yaml_value = flat_llm_yaml.get(field_name) | ||||||
|  |                     if yaml_value is not None: | ||||||
|  |                         setattr(self.llm, field_name, yaml_value) | ||||||
|  | 
 | ||||||
|  |         # --- Processor Configuration --- | ||||||
|  |         processor_yaml_config = yaml_config.get('processor', {}) | ||||||
|  |         if processor_yaml_config: | ||||||
|  |             for field_name in self.processor.model_fields: | ||||||
|  |                 if field_name not in self.processor.model_fields_set: | ||||||
|  |                     yaml_value = processor_yaml_config.get(field_name) | ||||||
|  |                     if yaml_value is not None: | ||||||
|  |                         setattr(self.processor, field_name, yaml_value) | ||||||
|  | 
 | ||||||
|  |         # --- Langfuse Configuration --- | ||||||
|  |         langfuse_yaml_config = yaml_config.get('langfuse', {}) | ||||||
|  |         if langfuse_yaml_config: | ||||||
|  |             for field_name in self.langfuse.model_fields: | ||||||
|  |                 if field_name not in self.langfuse.model_fields_set: | ||||||
|  |                     yaml_value = langfuse_yaml_config.get(field_name) | ||||||
|  |                     if yaml_value is not None: | ||||||
|  |                         setattr(self.langfuse, field_name, yaml_value) | ||||||
|  | 
 | ||||||
|     def _load_yaml_config(self): |     def _load_yaml_config(self): | ||||||
|         config_path = Path('config/application.yml') |         config_path = Path('config/application.yml') | ||||||
|         if not config_path.exists(): |         if not config_path.exists(): | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Ireneusz Bachanowicz
						Ireneusz Bachanowicz