mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-26 17:23:00 +00:00 
			
		
		
		
	We would like to rename the term `template` to `distribution`. To prepare for that, this is a precursor. cc @leseb
		
			
				
	
	
		
			55 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (c) Meta Platforms, Inc. and affiliates.
 | |
| # All rights reserved.
 | |
| #
 | |
| # This source code is licensed under the terms described in the LICENSE file in
 | |
| # the root directory of this source tree.
 | |
| 
 | |
| from enum import StrEnum
 | |
| from typing import Any
 | |
| 
 | |
| from pydantic import BaseModel, Field, field_validator
 | |
| 
 | |
| from llama_stack.core.utils.config_dirs import RUNTIME_BASE_DIR
 | |
| 
 | |
| 
 | |
| class TelemetrySink(StrEnum):
 | |
|     OTEL_TRACE = "otel_trace"
 | |
|     OTEL_METRIC = "otel_metric"
 | |
|     SQLITE = "sqlite"
 | |
|     CONSOLE = "console"
 | |
| 
 | |
| 
 | |
| class TelemetryConfig(BaseModel):
 | |
|     otel_exporter_otlp_endpoint: str | None = Field(
 | |
|         default=None,
 | |
|         description="The OpenTelemetry collector endpoint URL (base URL for traces, metrics, and logs). If not set, the SDK will use OTEL_EXPORTER_OTLP_ENDPOINT environment variable.",
 | |
|     )
 | |
|     service_name: str = Field(
 | |
|         # service name is always the same, use zero-width space to avoid clutter
 | |
|         default="\u200b",
 | |
|         description="The service name to use for telemetry",
 | |
|     )
 | |
|     sinks: list[TelemetrySink] = Field(
 | |
|         default=[TelemetrySink.CONSOLE, TelemetrySink.SQLITE],
 | |
|         description="List of telemetry sinks to enable (possible values: otel_trace, otel_metric, sqlite, console)",
 | |
|     )
 | |
|     sqlite_db_path: str = Field(
 | |
|         default_factory=lambda: (RUNTIME_BASE_DIR / "trace_store.db").as_posix(),
 | |
|         description="The path to the SQLite database to use for storing traces",
 | |
|     )
 | |
| 
 | |
|     @field_validator("sinks", mode="before")
 | |
|     @classmethod
 | |
|     def validate_sinks(cls, v):
 | |
|         if isinstance(v, str):
 | |
|             return [TelemetrySink(sink.strip()) for sink in v.split(",")]
 | |
|         return v
 | |
| 
 | |
|     @classmethod
 | |
|     def sample_run_config(cls, __distro_dir__: str, db_name: str = "trace_store.db") -> dict[str, Any]:
 | |
|         return {
 | |
|             "service_name": "${env.OTEL_SERVICE_NAME:=\u200b}",
 | |
|             "sinks": "${env.TELEMETRY_SINKS:=console,sqlite}",
 | |
|             "sqlite_db_path": "${env.SQLITE_STORE_DIR:=" + __distro_dir__ + "}/" + db_name,
 | |
|             "otel_exporter_otlp_endpoint": "${env.OTEL_EXPORTER_OTLP_ENDPOINT:=}",
 | |
|         }
 |