ehhuang 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								07ff15d917 
								
							 
						 
						
							
							
								
								chore: distrogen enables telemetry by default ( #3828 )  
							
							... 
							
							
							
							# What does this PR do?
leftover from #3815 
## Test Plan
CI
---
[//]: # (BEGIN SAPLING FOOTER)
Stack created with [Sapling](https://sapling-scm.com ). Best reviewed
with
[ReviewStack](https://reviewstack.dev/llamastack/llama-stack/pull/3828 ).
* #3830 
* __->__ #3828  
							
						 
						
							2025-10-16 11:29:51 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Charlie Doern 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								f22aaef42f 
								
							 
						 
						
							
							
								
								chore!: remove telemetry API usage ( #3815 )  
							
							... 
							
							
							
							# What does this PR do?
remove telemetry as a providable API from the codebase. This includes
removing it from generated distributions but also the provider registry,
the router, etc
since `setup_logger` is tied pretty strictly to `Api.telemetry` being in
impls we still need an "instantiated provider" in our implementations.
However it should not be auto-routed or provided. So in
validate_and_prepare_providers (called from resolve_impls) I made it so
that if run_config.telemetry.enabled, we set up the meta-reference
"provider" internally to be used so that log_event will work when
called.
This is the neatest way I think we can remove telemetry from the
provider configs but also not need to rip apart the whole "telemetry is
a provider" logic just yet, but we can do it internally later without
disrupting users.
so telemetry is removed from the registry such that if a user puts
`telemetry:` as an API in their build/run config it will err out, but
can still be used by us internally as we go through this transition.
relates to #3806 
Signed-off-by: Charlie Doern <cdoern@redhat.com> 
							
						 
						
							2025-10-16 10:39:32 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ehhuang 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								6ba9db3929 
								
							 
						 
						
							
							
								
								chore!: BREAKING CHANGE: remove sqlite from telemetry config ( #3808 )  
							
							... 
							
							
							
							# What does this PR do?
- Removed sqlite sink from telemetry config.
- Removed related code
- Updated doc related to telemetry
## Test Plan
CI 
							
						 
						
							2025-10-15 14:24:45 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Francisco Arceo 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								e7d21e1ee3 
								
							 
						 
						
							
							
								
								feat: Add support for Conversations in Responses API ( #3743 )  
							
							... 
							
							
							
							# What does this PR do?
This PR adds support for Conversations in Responses.
<!-- If resolving an issue, uncomment and update the line below -->
<!-- Closes #[issue-number] -->
## Test Plan
Unit tests
Integration tests
<Details>
<Summary>Manual testing with this script: (click to expand)</Summary>
```python
from openai import OpenAI
client = OpenAI()
client = OpenAI(base_url="http://localhost:8321/v1/ ", api_key="none")
def test_conversation_create():
    print("Testing conversation create...")
    conversation = client.conversations.create(
        metadata={"topic": "demo"},
        items=[
            {"type": "message", "role": "user", "content": "Hello!"}
        ]
    )
    print(f"Created: {conversation}")
    return conversation
def test_conversation_retrieve(conv_id):
    print(f"Testing conversation retrieve for {conv_id}...")
    retrieved = client.conversations.retrieve(conv_id)
    print(f"Retrieved: {retrieved}")
    return retrieved
def test_conversation_update(conv_id):
    print(f"Testing conversation update for {conv_id}...")
    updated = client.conversations.update(
        conv_id,
        metadata={"topic": "project-x"}
    )
    print(f"Updated: {updated}")
    return updated
def test_conversation_delete(conv_id):
    print(f"Testing conversation delete for {conv_id}...")
    deleted = client.conversations.delete(conv_id)
    print(f"Deleted: {deleted}")
    return deleted
def test_conversation_items_create(conv_id):
    print(f"Testing conversation items create for {conv_id}...")
    items = client.conversations.items.create(
        conv_id,
        items=[
            {
                "type": "message",
                "role": "user",
                "content": [{"type": "input_text", "text": "Hello!"}]
            },
            {
                "type": "message",
                "role": "user",
                "content": [{"type": "input_text", "text": "How are you?"}]
            }
        ]
    )
    print(f"Items created: {items}")
    return items
def test_conversation_items_list(conv_id):
    print(f"Testing conversation items list for {conv_id}...")
    items = client.conversations.items.list(conv_id, limit=10)
    print(f"Items list: {items}")
    return items
def test_conversation_item_retrieve(conv_id, item_id):
    print(f"Testing conversation item retrieve for {conv_id}/{item_id}...")
    item = client.conversations.items.retrieve(conversation_id=conv_id, item_id=item_id)
    print(f"Item retrieved: {item}")
    return item
def test_conversation_item_delete(conv_id, item_id):
    print(f"Testing conversation item delete for {conv_id}/{item_id}...")
    deleted = client.conversations.items.delete(conversation_id=conv_id, item_id=item_id)
    print(f"Item deleted: {deleted}")
    return deleted
def test_conversation_responses_create():
    print("\nTesting conversation create for a responses example...")
    conversation = client.conversations.create()
    print(f"Created: {conversation}")
    response = client.responses.create(
      model="gpt-4.1",
      input=[{"role": "user", "content": "What are the 5 Ds of dodgeball?"}],
      conversation=conversation.id,
    )
    print(f"Created response: {response} for conversation {conversation.id}")
    return response, conversation
def test_conversations_responses_create_followup(
        conversation,
        content="Repeat what you just said but add 'this is my second time saying this'",
    ):
    print(f"Using: {conversation.id}")
    response = client.responses.create(
      model="gpt-4.1",
      input=[{"role": "user", "content": content}],
      conversation=conversation.id,
    )
    print(f"Created response: {response} for conversation {conversation.id}")
    conv_items = client.conversations.items.list(conversation.id)
    print(f"\nRetrieving list of items for conversation {conversation.id}:")
    print(conv_items.model_dump_json(indent=2))
def test_response_with_fake_conv_id():
    fake_conv_id = "conv_zzzzzzzzz5dc81908289d62779d2ac510a2b0b602ef00a44"
    print(f"Using {fake_conv_id}")
    try:
        response = client.responses.create(
          model="gpt-4.1",
          input=[{"role": "user", "content": "say hello"}],
          conversation=fake_conv_id,
        )
        print(f"Created response: {response} for conversation {fake_conv_id}")
    except Exception as e:
        print(f"failed to create response for conversation {fake_conv_id} with error {e}")
def main():
    print("Testing OpenAI Conversations API...")
    # Create conversation
    conversation = test_conversation_create()
    conv_id = conversation.id
    # Retrieve conversation
    test_conversation_retrieve(conv_id)
    # Update conversation
    test_conversation_update(conv_id)
    # Create items
    items = test_conversation_items_create(conv_id)
    # List items
    items_list = test_conversation_items_list(conv_id)
    # Retrieve specific item
    if items_list.data:
        item_id = items_list.data[0].id
        test_conversation_item_retrieve(conv_id, item_id)
        # Delete item
        test_conversation_item_delete(conv_id, item_id)
    # Delete conversation
    test_conversation_delete(conv_id)
    response, conversation2 = test_conversation_responses_create()
    print('\ntesting reseponse retrieval')
    test_conversation_retrieve(conversation2.id)
    print('\ntesting responses follow up')
    test_conversations_responses_create_followup(conversation2)
    print('\ntesting responses follow up x2!')
    test_conversations_responses_create_followup(
        conversation2,
        content="Repeat what you just said but add 'this is my third time saying this'",
    )
    test_response_with_fake_conv_id()
    print("All tests completed!")
if __name__ == "__main__":
    main()
```
</Details>
---------
Signed-off-by: Francisco Javier Arceo <farceo@redhat.com>
Co-authored-by: Ashwin Bharambe <ashwin.bharambe@gmail.com> 
							
						 
						
							2025-10-10 11:57:40 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ehhuang 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								a3f5072776 
								
							 
						 
						
							
							
								
								chore!: remove --env from llama stack run ( #3711 )  
							
							... 
							
							
	
		
			
	 
	
	
		
	
	
		
			
				
	Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 1s 
				
			 
		
			
				
	SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 1s 
				
			 
		
			
				
	Installer CI / lint (push) Failing after 2s 
				
			 
		
			
				
	SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 0s 
				
			 
		
			
				
	Installer CI / smoke-test-on-dev (push) Failing after 2s 
				
			 
		
			
				
	Integration Tests (Replay) / Integration Tests (, , , client=, ) (push) Failing after 3s 
				
			 
		
			
				
	Test Llama Stack Build / generate-matrix (push) Successful in 3s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (push) Failing after 4s 
				
			 
		
			
				
	Test External Providers Installed via Module / test-external-providers-from-module (venv) (push) Has been skipped 
				
			 
		
			
				
	Test Llama Stack Build / build-custom-container-distribution (push) Failing after 2s 
				
			 
		
			
				
	Test Llama Stack Build / build-single-provider (push) Failing after 4s 
				
			 
		
			
				
	Python Package Build Test / build (3.12) (push) Failing after 2s 
				
			 
		
			
				
	Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 3s 
				
			 
		
			
				
	Python Package Build Test / build (3.13) (push) Failing after 1s 
				
			 
		
			
				
	API Conformance Tests / check-schema-compatibility (push) Successful in 10s 
				
			 
		
			
				
	Unit Tests / unit-tests (3.12) (push) Failing after 3s 
				
			 
		
			
				
	Test Llama Stack Build / build (push) Failing after 3s 
				
			 
		
			
				
	Test External API and Providers / test-external (venv) (push) Failing after 3s 
				
			 
		
			
				
	Unit Tests / unit-tests (3.13) (push) Failing after 3s 
				
			 
		
			
				
	UI Tests / ui-tests (22) (push) Successful in 40s 
				
			 
		
			
				
	Pre-commit / pre-commit (push) Successful in 1m18s 
				
			 
		
		
	 
 
	 
							
							# What does this PR do?
user can simply set env vars in the beginning of the command.`FOO=BAR
llama stack run ...`
## Test Plan
Run
TELEMETRY_SINKS=coneol uv run --with llama-stack llama stack build
--distro=starter --image-type=venv --run
---
[//]: # (BEGIN SAPLING FOOTER)
Stack created with [Sapling](https://sapling-scm.com ). Best reviewed
with
[ReviewStack](https://reviewstack.dev/llamastack/llama-stack/pull/3711 ).
* #3714 
* __->__ #3711  
							
						 
						
							2025-10-07 20:58:15 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Ashwin Bharambe 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								42414a1a1b 
								
							 
						 
						
							
							
								
								fix(logging): disable console telemetry sink by default ( #3623 )  
							
							... 
							
							
	
		
			
	 
	
	
		
	
	
		
			
				
	SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 0s 
				
			 
		
			
				
	SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 0s 
				
			 
		
			
				
	Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 0s 
				
			 
		
			
				
	Test External Providers Installed via Module / test-external-providers-from-module (venv) (push) Has been skipped 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (push) Failing after 3s 
				
			 
		
			
				
	Test Llama Stack Build / generate-matrix (push) Successful in 3s 
				
			 
		
			
				
	Python Package Build Test / build (3.12) (push) Failing after 1s 
				
			 
		
			
				
	Test Llama Stack Build / build-custom-container-distribution (push) Failing after 3s 
				
			 
		
			
				
	Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 3s 
				
			 
		
			
				
	Test External API and Providers / test-external (venv) (push) Failing after 4s 
				
			 
		
			
				
	Unit Tests / unit-tests (3.13) (push) Failing after 3s 
				
			 
		
			
				
	Test Llama Stack Build / build (push) Failing after 4s 
				
			 
		
			
				
	Python Package Build Test / build (3.13) (push) Failing after 21s 
				
			 
		
			
				
	Test Llama Stack Build / build-single-provider (push) Failing after 25s 
				
			 
		
			
				
	Integration Tests (Replay) / Integration Tests (, , , client=, ) (push) Failing after 27s 
				
			 
		
			
				
	Unit Tests / unit-tests (3.12) (push) Failing after 22s 
				
			 
		
			
				
	API Conformance Tests / check-schema-compatibility (push) Successful in 33s 
				
			 
		
			
				
	UI Tests / ui-tests (22) (push) Successful in 39s 
				
			 
		
			
				
	Pre-commit / pre-commit (push) Successful in 1m12s 
				
			 
		
		
	 
 
	 
							
							The current span processing dumps so much junk on the console that it
makes actual understanding of what is going on in the server impossible.
I am killing the console sink as a default. If you want, you are always
free to change your run.yaml to add it.
Before: 
<img width="1877" height="1107" alt="image"
src="https://github.com/user-attachments/assets/3a7ad261-e2ba-4d40-9820-fcc282c8df37 "
/>
After:
<img width="1919" height="470" alt="image"
src="https://github.com/user-attachments/assets/bc7cf763-fba9-4e95-a4b5-f65f6d1c5332 "
/> 
							
						 
						
							2025-09-30 14:58:05 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Matthew Farrellee 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								b67aef2fc4 
								
							 
						 
						
							
							
								
								feat: add static embedding metadata to dynamic model listings for providers using OpenAIMixin ( #3547 )  
							
							... 
							
							
							
							# What does this PR do?
- remove auto-download of ollama embedding models
- add embedding model metadata to dynamic listing w/ unit test
- add support and tests for allowed_models
- removed inference provider models.py files where dynamic listing is
enabled
- store embedding metadata in embedding_model_metadata field on
inference providers
- make model_entries optional on ModelRegistryHelper and
LiteLLMOpenAIMixin
- make OpenAIMixin a ModelRegistryHelper
- skip base64 embedding test for remote::ollama, always returns floats
- only use OpenAI client for ollama model listing
- remove unused build_model_entry function
- remove unused get_huggingface_repo function
## Test Plan
ci w/ new tests 
							
						 
						
							2025-09-25 17:17:00 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Alexey Rybak 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								d23865757f 
								
							 
						 
						
							
							
								
								docs: provider and distro codegen migration ( #3531 )  
							
							... 
							
							
							
							# What does this PR do?
<!-- Provide a short summary of what this PR does and why. Link to relevant issues if applicable. -->
<!-- If resolving an issue, uncomment and update the line below -->
<!-- Closes #[issue-number] -->
- Updates provider and distro codegen to handle the new format
- Migrates provider and distro files to the new format
## Test Plan
- Manual testing
<!-- Describe the tests you ran to verify your changes with result summaries. *Provide clear instructions so the plan can be easily re-executed.* --> 
							
						 
						
							2025-09-24 14:01:29 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Jiayi Ni 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								e66103c09d 
								
							 
						 
						
							
							
								
								fix: add missing files provider to NVIDIA distribution ( #3479 )  
							
							... 
							
							
							
							# What does this PR do?
The rag-runtime tool requires files API as a dependency, but the NVIDIA
distribution was missing the files provider configuration. Thus, when
running:
```
llama stack build --distro nvidia --image-type venv
```
And then:
```
llama stack run {path_to_distribution_config} --image-type venv
```
It would raise an error:
```
RuntimeError: Failed to resolve 'tool_runtime' provider 'rag-runtime' of type 'inline::rag-runtime': required dependency 'files' is not available. Please add a 'files' provider to your configuration or check if the provider is properly configured.
```
This PR fixes the issue by adding missing files provider to NVIDIA
distribution.
## Test Plan
N/A 
							
						 
						
							2025-09-18 13:49:46 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Jiayi Ni 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								b12cd528ef 
								
							 
						 
						
							
							
								
								docs: add VLM NIM example ( #3277 )  
							
							
	
		
			
	 
	
	
		
	
	
		
			
				
	Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 1s 
				
			 
		
			
				
	Integration Tests (Replay) / Integration Tests (, , , client=, vision=) (push) Failing after 1s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (push) Failing after 1s 
				
			 
		
			
				
	SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 2s 
				
			 
		
			
				
	Pre-commit / pre-commit (push) Failing after 0s 
				
			 
		
			
				
	Test Llama Stack Build / build-single-provider (push) Failing after 1s 
				
			 
		
			
				
	Test Llama Stack Build / build-custom-container-distribution (push) Failing after 0s 
				
			 
		
			
				
	Test Llama Stack Build / generate-matrix (push) Failing after 1s 
				
			 
		
			
				
	Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 1s 
				
			 
		
			
				
	Test Llama Stack Build / build (push) Has been skipped 
				
			 
		
			
				
	Test External Providers Installed via Module / test-external-providers-from-module (venv) (push) Has been skipped 
				
			 
		
			
				
	Python Package Build Test / build (3.12) (push) Failing after 1s 
				
			 
		
			
				
	Python Package Build Test / build (3.13) (push) Failing after 1s 
				
			 
		
			
				
	SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 5s 
				
			 
		
			
				
	Test External API and Providers / test-external (venv) (push) Failing after 1s 
				
			 
		
			
				
	UI Tests / ui-tests (22) (push) Failing after 0s 
				
			 
		
			
				
	Unit Tests / unit-tests (3.12) (push) Failing after 1s 
				
			 
		
			
				
	Unit Tests / unit-tests (3.13) (push) Failing after 0s 
				
			 
		
			
				
	Update ReadTheDocs / update-readthedocs (push) Failing after 1s 
				
			 
		
		
	 
 
	 
							
						 
						
							2025-08-29 16:23:52 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Jiayi Ni 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								9e78f2da96 
								
							 
						 
						
							
							
								
								docs: fix the docs for NVIDIA Inference Provider ( #3055 )  
							
							... 
							
							
	
		
			
	 
	
	
		
	
	
		
			
				
	Vector IO Integration Tests / test-matrix (3.12, remote::pgvector) (push) Failing after 15s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.12, remote::chromadb) (push) Failing after 20s 
				
			 
		
			
				
	SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 21s 
				
			 
		
			
				
	Test External Providers Installed via Module / test-external-providers-from-module (venv) (push) Has been skipped 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.13, remote::pgvector) (push) Failing after 15s 
				
			 
		
			
				
	Test Llama Stack Build / build-single-provider (push) Failing after 11s 
				
			 
		
			
				
	Test Llama Stack Build / generate-matrix (push) Successful in 14s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.12, inline::milvus) (push) Failing after 17s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.12, inline::sqlite-vec) (push) Failing after 17s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.12, inline::faiss) (push) Failing after 20s 
				
			 
		
			
				
	SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 26s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.13, inline::faiss) (push) Failing after 16s 
				
			 
		
			
				
	Test External API and Providers / test-external (venv) (push) Failing after 11s 
				
			 
		
			
				
	Unit Tests / unit-tests (3.12) (push) Failing after 12s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.13, inline::milvus) (push) Failing after 21s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.12, remote::weaviate) (push) Failing after 18s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.13, remote::qdrant) (push) Failing after 20s 
				
			 
		
			
				
	Python Package Build Test / build (3.12) (push) Failing after 23s 
				
			 
		
			
				
	Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 25s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.13, inline::sqlite-vec) (push) Failing after 18s 
				
			 
		
			
				
	Unit Tests / unit-tests (3.13) (push) Failing after 9s 
				
			 
		
			
				
	Update ReadTheDocs / update-readthedocs (push) Failing after 9s 
				
			 
		
			
				
	Python Package Build Test / build (3.13) (push) Failing after 21s 
				
			 
		
			
				
	Integration Tests (Replay) / Integration Tests (, , , client=, vision=) (push) Failing after 10s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.13, remote::weaviate) (push) Failing after 17s 
				
			 
		
			
				
	Test Llama Stack Build / build-custom-container-distribution (push) Failing after 51s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.12, remote::qdrant) (push) Failing after 58s 
				
			 
		
			
				
	Vector IO Integration Tests / test-matrix (3.13, remote::chromadb) (push) Failing after 56s 
				
			 
		
			
				
	Pre-commit / pre-commit (push) Successful in 1m40s 
				
			 
		
			
				
	Test Llama Stack Build / build (push) Failing after 14s 
				
			 
		
		
	 
 
	 
							
							# What does this PR do?
Fix the NVIDIA inference docs by updating API methods, model IDs, and
embedding example.
## Test Plan
N/A 
							
						 
						
							2025-08-08 11:27:55 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Ashwin Bharambe 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								cc87995e2b 
								
							 
						 
						
							
							
								
								chore: rename templates to distributions ( #3035 )  
							
							... 
							
							
							
							As the title says. Distributions is in, Templates is out.
`llama stack build --template` --> `llama stack build --distro`. For
backward compatibility, the previous option is kept but results in a
warning.
Updated `server.py` to remove the "config_or_template" backward
compatibility since it has been a couple releases since that change. 
							
						 
						
							2025-08-04 11:34:17 -07:00