forked from phoenix-oss/llama-stack-mirror
		
	* wip * scoring fn api * eval api * eval task * evaluate api update * pre commit * unwrap context -> config * config field doc * typo * naming fix * separate benchmark / app eval * api name * rename * wip tests * wip * datasetio test * delete unused * fixture * scoring resolve * fix scoring register * scoring test pass * score batch * scoring fix * fix eval * test eval works * remove type ignore * api refactor * add default task_eval_id for routing * add eval_id for jobs * remove type ignore * only keep 1 run_eval * fix optional * register task required * register task required * delete old tests * delete old tests * fixture return impl
		
			
				
	
	
		
			70 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
	
		
			1.9 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.
 | |
| 
 | |
| import importlib
 | |
| from typing import Dict, List
 | |
| 
 | |
| from pydantic import BaseModel
 | |
| 
 | |
| from llama_stack.providers.datatypes import Api, ProviderSpec, remote_provider_spec
 | |
| 
 | |
| 
 | |
| def stack_apis() -> List[Api]:
 | |
|     return [v for v in Api]
 | |
| 
 | |
| 
 | |
| class AutoRoutedApiInfo(BaseModel):
 | |
|     routing_table_api: Api
 | |
|     router_api: Api
 | |
| 
 | |
| 
 | |
| def builtin_automatically_routed_apis() -> List[AutoRoutedApiInfo]:
 | |
|     return [
 | |
|         AutoRoutedApiInfo(
 | |
|             routing_table_api=Api.models,
 | |
|             router_api=Api.inference,
 | |
|         ),
 | |
|         AutoRoutedApiInfo(
 | |
|             routing_table_api=Api.shields,
 | |
|             router_api=Api.safety,
 | |
|         ),
 | |
|         AutoRoutedApiInfo(
 | |
|             routing_table_api=Api.memory_banks,
 | |
|             router_api=Api.memory,
 | |
|         ),
 | |
|         AutoRoutedApiInfo(
 | |
|             routing_table_api=Api.datasets,
 | |
|             router_api=Api.datasetio,
 | |
|         ),
 | |
|         AutoRoutedApiInfo(
 | |
|             routing_table_api=Api.scoring_functions,
 | |
|             router_api=Api.scoring,
 | |
|         ),
 | |
|         AutoRoutedApiInfo(
 | |
|             routing_table_api=Api.eval_tasks,
 | |
|             router_api=Api.eval,
 | |
|         ),
 | |
|     ]
 | |
| 
 | |
| 
 | |
| def providable_apis() -> List[Api]:
 | |
|     routing_table_apis = set(
 | |
|         x.routing_table_api for x in builtin_automatically_routed_apis()
 | |
|     )
 | |
|     return [api for api in Api if api not in routing_table_apis and api != Api.inspect]
 | |
| 
 | |
| 
 | |
| def get_provider_registry() -> Dict[Api, Dict[str, ProviderSpec]]:
 | |
|     ret = {}
 | |
|     for api in providable_apis():
 | |
|         name = api.name.lower()
 | |
|         module = importlib.import_module(f"llama_stack.providers.registry.{name}")
 | |
|         ret[api] = {
 | |
|             "remote": remote_provider_spec(api),
 | |
|             **{a.provider_type: a for a in module.available_providers()},
 | |
|         }
 | |
| 
 | |
|     return ret
 |