mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-25 17:11:12 +00:00 
			
		
		
		
	# What does this PR do? The goal of this PR is code base modernization. Schema reflection code needed a minor adjustment to handle UnionTypes and collections.abc.AsyncIterator. (Both are preferred for latest Python releases.) Note to reviewers: almost all changes here are automatically generated by pyupgrade. Some additional unused imports were cleaned up. The only change worth of note can be found under `docs/openapi_generator` and `llama_stack/strong_typing/schema.py` where reflection code was updated to deal with "newer" types. Signed-off-by: Ihar Hrachyshka <ihar.hrachyshka@gmail.com>
		
			
				
	
	
		
			80 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
	
		
			2.8 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 llama_stack.apis.datasetio import DatasetIO
 | |
| from llama_stack.apis.telemetry import QueryCondition, QuerySpansResponse, Span
 | |
| 
 | |
| 
 | |
| class TelemetryDatasetMixin:
 | |
|     """Mixin class that provides dataset-related functionality for telemetry providers."""
 | |
| 
 | |
|     datasetio_api: DatasetIO | None
 | |
| 
 | |
|     async def save_spans_to_dataset(
 | |
|         self,
 | |
|         attribute_filters: list[QueryCondition],
 | |
|         attributes_to_save: list[str],
 | |
|         dataset_id: str,
 | |
|         max_depth: int | None = None,
 | |
|     ) -> None:
 | |
|         if self.datasetio_api is None:
 | |
|             raise RuntimeError("DatasetIO API not available")
 | |
| 
 | |
|         spans = await self.query_spans(
 | |
|             attribute_filters=attribute_filters,
 | |
|             attributes_to_return=attributes_to_save,
 | |
|             max_depth=max_depth,
 | |
|         )
 | |
| 
 | |
|         rows = [
 | |
|             {
 | |
|                 "trace_id": span.trace_id,
 | |
|                 "span_id": span.span_id,
 | |
|                 "parent_span_id": span.parent_span_id,
 | |
|                 "name": span.name,
 | |
|                 "start_time": span.start_time,
 | |
|                 "end_time": span.end_time,
 | |
|                 **{attr: span.attributes.get(attr) for attr in attributes_to_save},
 | |
|             }
 | |
|             for span in spans
 | |
|         ]
 | |
| 
 | |
|         await self.datasetio_api.append_rows(dataset_id=dataset_id, rows=rows)
 | |
| 
 | |
|     async def query_spans(
 | |
|         self,
 | |
|         attribute_filters: list[QueryCondition],
 | |
|         attributes_to_return: list[str],
 | |
|         max_depth: int | None = None,
 | |
|     ) -> QuerySpansResponse:
 | |
|         traces = await self.query_traces(attribute_filters=attribute_filters)
 | |
|         spans = []
 | |
| 
 | |
|         for trace in traces.data:
 | |
|             spans_by_id_resp = await self.get_span_tree(
 | |
|                 span_id=trace.root_span_id,
 | |
|                 attributes_to_return=attributes_to_return,
 | |
|                 max_depth=max_depth,
 | |
|             )
 | |
| 
 | |
|             for span in spans_by_id_resp.data.values():
 | |
|                 if span.attributes and all(
 | |
|                     attr in span.attributes and span.attributes[attr] is not None for attr in attributes_to_return
 | |
|                 ):
 | |
|                     spans.append(
 | |
|                         Span(
 | |
|                             trace_id=trace.root_span_id,
 | |
|                             span_id=span.span_id,
 | |
|                             parent_span_id=span.parent_span_id,
 | |
|                             name=span.name,
 | |
|                             start_time=span.start_time,
 | |
|                             end_time=span.end_time,
 | |
|                             attributes=span.attributes,
 | |
|                         )
 | |
|                     )
 | |
| 
 | |
|         return QuerySpansResponse(data=spans)
 |