mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-25 01:01:13 +00:00 
			
		
		
		
	
		
			Some checks failed
		
		
	
	Unit Tests / unit-tests (3.13) (push) Failing after 3s
				
			UI Tests / ui-tests (22) (push) Successful in 36s
				
			Update ReadTheDocs / update-readthedocs (push) Failing after 3s
				
			Test Llama Stack Build / build (push) Failing after 4s
				
			Pre-commit / pre-commit (push) Successful in 1m12s
				
			SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 1s
				
			Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 2s
				
			Integration Tests (Replay) / Integration Tests (, , , client=, ) (push) Failing after 3s
				
			Test External Providers Installed via Module / test-external-providers-from-module (venv) (push) Has been skipped
				
			Python Package Build Test / build (3.13) (push) Failing after 1s
				
			Test Llama Stack Build / build-single-provider (push) Failing after 3s
				
			Test Llama Stack Build / build-custom-container-distribution (push) Failing after 3s
				
			Unit Tests / unit-tests (3.12) (push) Failing after 3s
				
			Python Package Build Test / build (3.12) (push) Failing after 2s
				
			SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 7s
				
			Vector IO Integration Tests / test-matrix (push) Failing after 5s
				
			API Conformance Tests / check-schema-compatibility (push) Successful in 7s
				
			Test Llama Stack Build / generate-matrix (push) Successful in 5s
				
			Test External API and Providers / test-external (venv) (push) Failing after 4s
				
			Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 3s
				
			# What does this PR do? currently `RemoteProviderSpec` has an `AdapterSpec` embedded in it. Remove `AdapterSpec`, and put its leftover fields into `RemoteProviderSpec`. Additionally, many of the fields were duplicated between `InlineProviderSpec` and `RemoteProviderSpec`. Move these to `ProviderSpec` so they are shared. Fixup the distro codegen to use `RemoteProviderSpec` directly rather than `remote_provider_spec` which took an AdapterSpec and returned a full provider spec ## Test Plan existing distro tests should pass. Signed-off-by: Charlie Doern <cdoern@redhat.com>
		
			
				
	
	
		
			87 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
	
		
			4.3 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.providers.datatypes import (
 | |
|     Api,
 | |
|     InlineProviderSpec,
 | |
|     ProviderSpec,
 | |
|     RemoteProviderSpec,
 | |
| )
 | |
| 
 | |
| 
 | |
| def available_providers() -> list[ProviderSpec]:
 | |
|     return [
 | |
|         InlineProviderSpec(
 | |
|             api=Api.tool_runtime,
 | |
|             provider_type="inline::rag-runtime",
 | |
|             pip_packages=[
 | |
|                 "chardet",
 | |
|                 "pypdf",
 | |
|                 "tqdm",
 | |
|                 "numpy",
 | |
|                 "scikit-learn",
 | |
|                 "scipy",
 | |
|                 "nltk",
 | |
|                 "sentencepiece",
 | |
|                 "transformers",
 | |
|             ],
 | |
|             module="llama_stack.providers.inline.tool_runtime.rag",
 | |
|             config_class="llama_stack.providers.inline.tool_runtime.rag.config.RagToolRuntimeConfig",
 | |
|             api_dependencies=[Api.vector_io, Api.inference, Api.files],
 | |
|             description="RAG (Retrieval-Augmented Generation) tool runtime for document ingestion, chunking, and semantic search.",
 | |
|         ),
 | |
|         RemoteProviderSpec(
 | |
|             api=Api.tool_runtime,
 | |
|             adapter_type="brave-search",
 | |
|             provider_type="remote::brave-search",
 | |
|             module="llama_stack.providers.remote.tool_runtime.brave_search",
 | |
|             config_class="llama_stack.providers.remote.tool_runtime.brave_search.config.BraveSearchToolConfig",
 | |
|             pip_packages=["requests"],
 | |
|             provider_data_validator="llama_stack.providers.remote.tool_runtime.brave_search.BraveSearchToolProviderDataValidator",
 | |
|             description="Brave Search tool for web search capabilities with privacy-focused results.",
 | |
|         ),
 | |
|         RemoteProviderSpec(
 | |
|             api=Api.tool_runtime,
 | |
|             adapter_type="bing-search",
 | |
|             provider_type="remote::bing-search",
 | |
|             module="llama_stack.providers.remote.tool_runtime.bing_search",
 | |
|             config_class="llama_stack.providers.remote.tool_runtime.bing_search.config.BingSearchToolConfig",
 | |
|             pip_packages=["requests"],
 | |
|             provider_data_validator="llama_stack.providers.remote.tool_runtime.bing_search.BingSearchToolProviderDataValidator",
 | |
|             description="Bing Search tool for web search capabilities using Microsoft's search engine.",
 | |
|         ),
 | |
|         RemoteProviderSpec(
 | |
|             api=Api.tool_runtime,
 | |
|             adapter_type="tavily-search",
 | |
|             provider_type="remote::tavily-search",
 | |
|             module="llama_stack.providers.remote.tool_runtime.tavily_search",
 | |
|             config_class="llama_stack.providers.remote.tool_runtime.tavily_search.config.TavilySearchToolConfig",
 | |
|             pip_packages=["requests"],
 | |
|             provider_data_validator="llama_stack.providers.remote.tool_runtime.tavily_search.TavilySearchToolProviderDataValidator",
 | |
|             description="Tavily Search tool for AI-optimized web search with structured results.",
 | |
|         ),
 | |
|         RemoteProviderSpec(
 | |
|             api=Api.tool_runtime,
 | |
|             adapter_type="wolfram-alpha",
 | |
|             provider_type="remote::wolfram-alpha",
 | |
|             module="llama_stack.providers.remote.tool_runtime.wolfram_alpha",
 | |
|             config_class="llama_stack.providers.remote.tool_runtime.wolfram_alpha.config.WolframAlphaToolConfig",
 | |
|             pip_packages=["requests"],
 | |
|             provider_data_validator="llama_stack.providers.remote.tool_runtime.wolfram_alpha.WolframAlphaToolProviderDataValidator",
 | |
|             description="Wolfram Alpha tool for computational knowledge and mathematical calculations.",
 | |
|         ),
 | |
|         RemoteProviderSpec(
 | |
|             api=Api.tool_runtime,
 | |
|             adapter_type="model-context-protocol",
 | |
|             provider_type="remote::model-context-protocol",
 | |
|             module="llama_stack.providers.remote.tool_runtime.model_context_protocol",
 | |
|             config_class="llama_stack.providers.remote.tool_runtime.model_context_protocol.config.MCPProviderConfig",
 | |
|             pip_packages=["mcp>=1.8.1"],
 | |
|             provider_data_validator="llama_stack.providers.remote.tool_runtime.model_context_protocol.config.MCPProviderDataValidator",
 | |
|             description="Model Context Protocol (MCP) tool for standardized tool calling and context management.",
 | |
|         ),
 | |
|     ]
 |