forked from phoenix-oss/llama-stack-mirror
		
	
		
			
				
	
	
	
	
		
			2.1 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			2.1 KiB
		
	
	
	
	
	
	
	
Adding a New API Provider
This guide will walk you through the process of adding a new API provider to Llama Stack.
- Begin by reviewing the core concepts of Llama Stack and choose the API your provider belongs to (Inference, Safety, VectorIO, etc.)
- Determine the provider type ({repopath}Remote::llama_stack/providers/remoteor {repopath}Inline::llama_stack/providers/inline). Remote providers make requests to external services, while inline providers execute implementation locally.
- Add your provider to the appropriate {repopath}Registry::llama_stack/providers/registry/. Specify pip dependencies necessary.
- Update any distribution {repopath}Templates::llama_stack/templates/build.yaml and run.yaml files if they should include your provider by default. Run {repopath}llama_stack/scripts/distro_codegen.pyif necessary.
Here are some example PRs to help you get started:
Testing the Provider
1. Integration Testing
- Create integration tests that use real provider instances and configurations
- For remote services, test actual API interactions
- Avoid mocking at the provider level since adapter layers tend to be thin
- Reference examples in {repopath}tests/client-sdk
2. Unit Testing (Optional)
- Add unit tests for provider-specific functionality
- See examples in {repopath}llama_stack/providers/tests/inference/test_text_inference.py
3. End-to-End Testing
- Start a Llama Stack server with your new provider
- Test using client requests
- Verify compatibility with existing client scripts in the llama-stack-apps repository
- Document which scripts are compatible with your provider
Submitting Your PR
- Ensure all tests pass
- Include a comprehensive test plan in your PR summary
- Document any known limitations or considerations
- Submit your pull request for review