Lightspeed Core Service (LCS) service API specification.
| URL | Description |
|---|---|
| http://localhost:8080/ | Locally running service |
Root Endpoint Handler
Handle GET requests to the root ("/") endpoint and returns the static HTML index page.
Returns: HTMLResponse: The HTML content of the index page, including a heading, embedded image with the service icon, and links to the API documentation via Swagger UI and ReDoc.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful Response | string |
| 401 | Unauthorized | ... |
| Examples |
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}UnauthorizedResponse | | 403 | Permission denied | ... Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}Info Endpoint Handler
Handle request to the /info endpoint.
Process GET requests to the /info endpoint, returning the service name, version and Llama-stack version.
Raises:
HTTPException: with status 500 and a detail object
containing response and cause when unable to connect to
Llama Stack. It can also return status 401 or 403 for
unauthorized access.
Returns: InfoResponse: An object containing the service's name and version.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | InfoResponse |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "Token has expired",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "Invalid token signature",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "Token signed by unknown key",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "Token missing claim: user_id",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "Invalid or expired Kubernetes token",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "Authentication key server returned invalid data",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 503 | Service unavailable | ServiceUnavailableResponse
Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}|
Models Endpoint Handler
Handle requests to the /models endpoint.
Process GET requests to the /models endpoint, returning a list of available models from the Llama Stack service. It is possible to specify "model_type" query parameter that is used as a filter. For example, if model type is set to "llm", only LLM models will be returned:
curl http://localhost:8080/v1/models?model_type=llm
The "model_type" query parameter is optional. When not specified, all models will be returned.
request: The incoming HTTP request.
auth: Authentication tuple from the auth dependency.
model_type: Optional filter to return only models matching this type.
HTTPException: If unable to connect to the Llama Stack server or if
model retrieval fails for any reason.
ModelsResponse: An object containing the list of available models.
| Name | Type | Required | Description |
|---|---|---|---|
| model_type | False | Optional filter to return only models matching this type |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ModelsResponse |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}| | 503 | Service unavailable | ServiceUnavailableResponse
Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}| | 422 | Validation Error | HTTPValidationError |
Tools Endpoint Handler
Handle requests to the /tools endpoint.
Process GET requests to the /tools endpoint, returning a consolidated list of available tools from all configured MCP servers.
Raises: HTTPException: If unable to connect to the Llama Stack server or if tool retrieval fails for any reason.
Returns: ToolsResponse: An object containing the consolidated list of available tools with metadata including tool name, description, parameters, and server source.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ToolsResponse |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}| | 503 | Service unavailable | ServiceUnavailableResponse
Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}|
Get Mcp Client Auth Options
Get MCP servers that accept client-provided authorization.
Returns a list of MCP servers configured to accept client-provided authorization tokens, along with the header names where clients should provide these tokens.
This endpoint helps clients discover which MCP servers they can authenticate with using their own tokens.
Args: request: The incoming HTTP request (used by middleware). auth: Authentication tuple from the auth dependency (used by middleware).
Returns: MCPClientAuthOptionsResponse: List of MCP servers and their accepted client authentication headers.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | MCPClientAuthOptionsResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 500 | Internal server error | InternalServerErrorResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}Shields Endpoint Handler
Handle requests to the /shields endpoint.
Process GET requests to the /shields endpoint, returning a list of available shields from the Llama Stack service.
Raises: HTTPException: If unable to connect to the Llama Stack server or if shield retrieval fails for any reason.
Returns: ShieldsResponse: An object containing the list of available shields.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ShieldsResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 503 | Service unavailable | ServiceUnavailableResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}Providers Endpoint Handler
List all available providers grouped by API type.
Returns: ProvidersListResponse: Mapping from API type to list of providers.
Raises: HTTPException: - 401: Authentication failed - 403: Authorization failed - 500: Lightspeed Stack configuration not loaded - 503: Unable to connect to Llama Stack
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ProvidersListResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 503 | Service unavailable | ServiceUnavailableResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}Get Provider Endpoint Handler
Retrieve a single provider identified by its unique ID.
Returns: ProviderResponse: Provider details.
Raises: HTTPException: - 401: Authentication failed - 403: Authorization failed - 404: Provider not found - 500: Lightspeed Stack configuration not loaded - 503: Unable to connect to Llama Stack
| Name | Type | Required | Description |
|---|---|---|---|
| provider_id | string | True |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ProviderResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 404 | Resource not found | NotFoundResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 503 | Service unavailable | ServiceUnavailableResponse |
| 422 | Validation Error | HTTPValidationError |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Provider with ID openai does not exist",
"response": "Provider not found"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}Rags Endpoint Handler
List all available RAGs.
Returns: RAGListResponse: List of RAG identifiers.
Raises: HTTPException: - 401: Authentication failed - 403: Authorization failed - 500: Lightspeed Stack configuration not loaded - 503: Unable to connect to Llama Stack
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | RAGListResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 503 | Service unavailable | ServiceUnavailableResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}Get Rag Endpoint Handler
Retrieve a single RAG identified by its unique ID.
Accepts both user-facing rag_id (from LCORE config) and llama-stack vector_store_id. If a rag_id from config is provided, it is resolved to the underlying vector_store_id for the llama-stack lookup.
Returns: RAGInfoResponse: A single RAG's details.
Raises: HTTPException: - 401: Authentication failed - 403: Authorization failed - 404: RAG with the given ID not found - 500: Lightspeed Stack configuration not loaded - 503: Unable to connect to Llama Stack
| Name | Type | Required | Description |
|---|---|---|---|
| rag_id | string | True |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | RAGInfoResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 404 | Resource not found | NotFoundResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 503 | Service unavailable | ServiceUnavailableResponse |
| 422 | Validation Error | HTTPValidationError |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Rag with ID vs_7b52a8cf-0fa3-489c-beab-27e061d102f3 does not exist",
"response": "Rag not found"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}Query Endpoint Handler
Handle request to the /query endpoint using Responses API.
Processes a POST request to a query endpoint, forwarding the user's query to a selected Llama Stack LLM and returning the generated response.
Returns: QueryResponse: Contains the conversation ID and the LLM-generated response.
Raises: HTTPException: - 401: Unauthorized - Missing or invalid credentials - 403: Forbidden - Insufficient permissions or model override not allowed - 404: Not Found - Conversation, model, or provider not found - 413: Prompt too long - Prompt exceeded model's context window size - 422: Unprocessable Entity - Request validation failed - 429: Quota limit exceeded - The token quota for model or user has been exceeded - 500: Internal Server Error - Configuration not loaded or other server errors - 503: Service Unavailable - Unable to connect to Llama Stack backend
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | QueryResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 404 | Resource not found | NotFoundResponse |
| 422 | Request validation failed | UnprocessableEntityResponse |
| 429 | Quota limit exceeded | QuotaExceededResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 503 | Service unavailable | ServiceUnavailableResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 does not have permission to read conversation with ID 123e4567-e89b-12d3-a456-426614174000",
"response": "User does not have permission to perform this action"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "User lacks model_override permission required to override model/provider.",
"response": "This instance does not permit overriding model/provider in the query request (missing permission: MODEL_OVERRIDE). Please remove the model and provider fields from your request."
}
}{
"detail": {
"cause": "Conversation with ID 123e4567-e89b-12d3-a456-426614174000 does not exist",
"response": "Conversation not found"
}
}{
"detail": {
"cause": "Provider with ID openai does not exist",
"response": "Provider not found"
}
}{
"detail": {
"cause": "Model with ID gpt-4-turbo is not configured",
"response": "Model not found"
}
}{
"detail": {
"cause": "Invalid request format. The request body could not be parsed.",
"response": "Invalid request format"
}
}{
"detail": {
"cause": "Missing required attributes: ['query', 'model', 'provider']",
"response": "Missing required attributes"
}
}{
"detail": {
"cause": "Invalid attachment type: must be one of ['text/plain', 'application/json', 'application/yaml', 'application/xml']",
"response": "Invalid attribute value"
}
}{
"detail": {
"cause": "The token quota for model gpt-4-turbo has been exceeded.",
"response": "The model quota has been exceeded"
}
}{
"detail": {
"cause": "User 123 has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Cluster has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Unknown subject 999 has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "User 123 has 5 tokens, but 10 tokens are needed.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Cluster has 500 tokens, but 900 tokens are needed.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Unknown subject 999 has 3 tokens, but 6 tokens are needed.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}Streaming Query Endpoint Handler
Handle request to the /streaming_query endpoint using Responses API.
Returns a streaming response using Server-Sent Events (SSE) format with content type text/event-stream.
Returns: SSE-formatted events for the query lifecycle.
Raises: HTTPException: - 401: Unauthorized - Missing or invalid credentials - 403: Forbidden - Insufficient permissions or model override not allowed - 404: Not Found - Conversation, model, or provider not found - 413: Prompt too long - Prompt exceeded model's context window size - 422: Unprocessable Entity - Request validation failed - 429: Quota limit exceeded - The token quota for model or user has been exceeded - 500: Internal Server Error - Configuration not loaded or other server errors - 503: Service Unavailable - Unable to connect to Llama Stack backend
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | string |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 404 | Resource not found | NotFoundResponse |
| 422 | Request validation failed | UnprocessableEntityResponse |
| 429 | Quota limit exceeded | QuotaExceededResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 503 | Service unavailable | ServiceUnavailableResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 does not have permission to read conversation with ID 123e4567-e89b-12d3-a456-426614174000",
"response": "User does not have permission to perform this action"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "User lacks model_override permission required to override model/provider.",
"response": "This instance does not permit overriding model/provider in the query request (missing permission: MODEL_OVERRIDE). Please remove the model and provider fields from your request."
}
}{
"detail": {
"cause": "Conversation with ID 123e4567-e89b-12d3-a456-426614174000 does not exist",
"response": "Conversation not found"
}
}{
"detail": {
"cause": "Provider with ID openai does not exist",
"response": "Provider not found"
}
}{
"detail": {
"cause": "Model with ID gpt-4-turbo is not configured",
"response": "Model not found"
}
}{
"detail": {
"cause": "Invalid request format. The request body could not be parsed.",
"response": "Invalid request format"
}
}{
"detail": {
"cause": "Missing required attributes: ['query', 'model', 'provider']",
"response": "Missing required attributes"
}
}{
"detail": {
"cause": "Invalid attachment type: must be one of ['text/plain', 'application/json', 'application/yaml', 'application/xml']",
"response": "Invalid attribute value"
}
}{
"detail": {
"cause": "The token quota for model gpt-4-turbo has been exceeded.",
"response": "The model quota has been exceeded"
}
}{
"detail": {
"cause": "User 123 has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Cluster has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Unknown subject 999 has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "User 123 has 5 tokens, but 10 tokens are needed.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Cluster has 500 tokens, but 900 tokens are needed.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Unknown subject 999 has 3 tokens, but 6 tokens are needed.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}Config Endpoint Handler
Handle requests to the /config endpoint.
Process GET requests to the /config endpoint and returns the current service configuration.
Ensures the application configuration is loaded before returning it.
Returns: ConfigurationResponse: The loaded service configuration response.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConfigurationResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 500 | Internal server error | InternalServerErrorResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}Feedback Endpoint Handler
Handle feedback requests.
Processes a user feedback submission, storing the feedback and returning a confirmation response.
Args: feedback_request: The request containing feedback information. ensure_feedback_enabled: The feedback handler (FastAPI Depends) that will handle feedback status checks. auth: The Authentication handler (FastAPI Depends) that will handle authentication Logic.
Returns: Response indicating the status of the feedback storage request.
Raises: HTTPException: Returns HTTP 404 if conversation does not exist. HTTPException: Returns HTTP 403 if conversation belongs to a different user. HTTPException: Returns HTTP 500 if feedback storage fails.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | FeedbackResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 404 | Resource not found | NotFoundResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 422 | Validation Error | HTTPValidationError |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Storing feedback is disabled.",
"response": "Storing feedback is disabled"
}
}{
"detail": {
"cause": "Conversation with ID 123e4567-e89b-12d3-a456-426614174000 does not exist",
"response": "Conversation not found"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Failed to store feedback at directory: /path/example",
"response": "Failed to store feedback"
}
}Feedback Status
Handle feedback status requests.
Return the current enabled status of the feedback functionality.
Returns: StatusResponse: Indicates whether feedback collection is enabled.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | StatusResponse |
Update Feedback Status
Handle feedback status update requests.
Takes a request with the desired state of the feedback status. Returns the updated state of the feedback status based on the request's value. These changes are for the life of the service and are on a per-worker basis.
Returns: FeedbackStatusUpdateResponse: Indicates whether feedback is enabled.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | FeedbackStatusUpdateResponse |
| 401 | Unauthorized | UnauthorizedResponse |
| 403 | Permission denied | ForbiddenResponse |
| 500 | Internal server error | InternalServerErrorResponse |
| 422 | Validation Error | HTTPValidationError |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}Conversations List Endpoint Handler V1
Handle request to retrieve all conversations for the authenticated user.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConversationsListResponse |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Failed to query the database",
"response": "Database query failed"
}
}|
Conversation Get Endpoint Handler V1
Handle request to retrieve a conversation identified by ID using Conversations API.
Retrieve a conversation's chat history by its ID using the LlamaStack Conversations API. This endpoint fetches the conversation items from the backend, simplifies them to essential chat history, and returns them in a structured response. Raises HTTP 400 for invalid IDs, 404 if not found, 503 if the backend is unavailable, and 500 for unexpected errors.
Args: request: The FastAPI request object conversation_id: Unique identifier of the conversation to retrieve auth: Authentication tuple from dependency
Returns: ConversationResponse: Structured response containing the conversation ID and simplified chat history
| Name | Type | Required | Description |
|---|---|---|---|
| conversation_id | string | True |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConversationResponse |
| 400 | Invalid request format | BadRequestResponse |
Examples
{
"detail": {
"cause": "The conversation ID 123e4567-e89b-12d3-a456-426614174000 has invalid format.",
"response": "Invalid conversation ID format"
}
}| | 401 | Unauthorized | UnauthorizedResponse
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 does not have permission to read conversation with ID 123e4567-e89b-12d3-a456-426614174000",
"response": "User does not have permission to perform this action"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 404 | Resource not found | NotFoundResponse
Examples
{
"detail": {
"cause": "Conversation with ID 123e4567-e89b-12d3-a456-426614174000 does not exist",
"response": "Conversation not found"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Failed to query the database",
"response": "Database query failed"
}
}| | 503 | Service unavailable | ServiceUnavailableResponse
Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}| | 422 | Validation Error | HTTPValidationError |
Conversation Delete Endpoint Handler V1
Handle request to delete a conversation by ID using Conversations API.
Validates the conversation ID format and attempts to delete the conversation from the Llama Stack backend using the Conversations API. Raises HTTP errors for invalid IDs, not found conversations, connection issues, or unexpected failures.
Args: request: The FastAPI request object conversation_id: Unique identifier of the conversation to delete auth: Authentication tuple from dependency
Returns: ConversationDeleteResponse: Response indicating the result of the deletion operation
| Name | Type | Required | Description |
|---|---|---|---|
| conversation_id | string | True |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConversationDeleteResponse |
Examples
{
"conversation_id": "123e4567-e89b-12d3-a456-426614174000",
"response": "Conversation deleted successfully",
"success": true
}{
"conversation_id": "123e4567-e89b-12d3-a456-426614174000",
"response": "Conversation can not be deleted",
"success": true
}| | 400 | Invalid request format | BadRequestResponse
Examples
{
"detail": {
"cause": "The conversation ID 123e4567-e89b-12d3-a456-426614174000 has invalid format.",
"response": "Invalid conversation ID format"
}
}| | 401 | Unauthorized | UnauthorizedResponse
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 does not have permission to delete conversation with ID 123e4567-e89b-12d3-a456-426614174000",
"response": "User does not have permission to perform this action"
}
}{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Failed to query the database",
"response": "Database query failed"
}
}| | 503 | Service unavailable | ServiceUnavailableResponse
Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}| | 422 | Validation Error | HTTPValidationError |
Conversation Update Endpoint Handler V1
Handle request to update a conversation metadata using Conversations API.
Updates the conversation metadata (including topic summary) in both the LlamaStack backend using the Conversations API and the local database.
Args: request: The FastAPI request object conversation_id: Unique identifier of the conversation to update update_request: Request containing the topic summary to update auth: Authentication tuple from dependency
Returns: ConversationUpdateResponse: Response indicating the result of the update operation
| Name | Type | Required | Description |
|---|---|---|---|
| conversation_id | string | True |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConversationUpdateResponse |
| 400 | Invalid request format | BadRequestResponse |
Examples
{
"detail": {
"cause": "The conversation ID 123e4567-e89b-12d3-a456-426614174000 has invalid format.",
"response": "Invalid conversation ID format"
}
}| | 401 | Unauthorized | UnauthorizedResponse
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 404 | Resource not found | NotFoundResponse
Examples
{
"detail": {
"cause": "Conversation with ID 123e4567-e89b-12d3-a456-426614174000 does not exist",
"response": "Conversation not found"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Failed to query the database",
"response": "Database query failed"
}
}| | 503 | Service unavailable | ServiceUnavailableResponse
Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}| | 422 | Validation Error | HTTPValidationError |
Get Conversations List Endpoint Handler
Handle request to retrieve all conversations for the authenticated user.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConversationsListResponseV2 |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Conversation cache is not configured or unavailable.",
"response": "Conversation cache not configured"
}
}|
Get Conversation Endpoint Handler
Handle request to retrieve a conversation identified by its ID.
| Name | Type | Required | Description |
|---|---|---|---|
| conversation_id | string | True |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConversationResponse |
| 400 | Invalid request format | BadRequestResponse |
Examples
{
"detail": {
"cause": "The conversation ID 123e4567-e89b-12d3-a456-426614174000 has invalid format.",
"response": "Invalid conversation ID format"
}
}| | 401 | Unauthorized | UnauthorizedResponse
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 404 | Resource not found | NotFoundResponse
Examples
{
"detail": {
"cause": "Conversation with ID 123e4567-e89b-12d3-a456-426614174000 does not exist",
"response": "Conversation not found"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Conversation cache is not configured or unavailable.",
"response": "Conversation cache not configured"
}
}| | 422 | Validation Error | HTTPValidationError |
Delete Conversation Endpoint Handler
Handle request to delete a conversation by ID.
| Name | Type | Required | Description |
|---|---|---|---|
| conversation_id | string | True |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConversationDeleteResponse |
Examples
{
"conversation_id": "123e4567-e89b-12d3-a456-426614174000",
"response": "Conversation deleted successfully",
"success": true
}{
"conversation_id": "123e4567-e89b-12d3-a456-426614174000",
"response": "Conversation can not be deleted",
"success": true
}| | 400 | Invalid request format | BadRequestResponse
Examples
{
"detail": {
"cause": "The conversation ID 123e4567-e89b-12d3-a456-426614174000 has invalid format.",
"response": "Invalid conversation ID format"
}
}| | 401 | Unauthorized | UnauthorizedResponse
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Conversation cache is not configured or unavailable.",
"response": "Conversation cache not configured"
}
}| | 422 | Validation Error | HTTPValidationError |
Update Conversation Endpoint Handler
Handle request to update a conversation topic summary by ID.
| Name | Type | Required | Description |
|---|---|---|---|
| conversation_id | string | True |
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ConversationUpdateResponse |
| 400 | Invalid request format | BadRequestResponse |
Examples
{
"detail": {
"cause": "The conversation ID 123e4567-e89b-12d3-a456-426614174000 has invalid format.",
"response": "Invalid conversation ID format"
}
}| | 401 | Unauthorized | UnauthorizedResponse
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 404 | Resource not found | NotFoundResponse
Examples
{
"detail": {
"cause": "Conversation with ID 123e4567-e89b-12d3-a456-426614174000 does not exist",
"response": "Conversation not found"
}
}| | 500 | Internal server error | InternalServerErrorResponse
Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}{
"detail": {
"cause": "Conversation cache is not configured or unavailable.",
"response": "Conversation cache not configured"
}
}| | 422 | Validation Error | HTTPValidationError |
Infer Endpoint
Handle rlsapi v1 /infer requests for stateless inference.
This endpoint serves requests from the RHEL Lightspeed Command Line Assistant (CLA).
Accepts a question with optional context (stdin, attachments, terminal output, system info) and returns an LLM-generated response.
Args: infer_request: The inference request containing question and context. request: The FastAPI request object for accessing headers and state. background_tasks: FastAPI background tasks for async Splunk event sending. auth: Authentication tuple from the configured auth provider.
Returns: RlsapiV1InferResponse containing the generated response text and request ID.
Raises: HTTPException: 503 if the LLM service is unavailable.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | RlsapiV1InferResponse |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 413 | Prompt is too long | PromptTooLongResponse
Examples
{
"detail": {
"cause": "The prompt exceeds the maximum allowed length.",
"response": "Prompt is too long"
}
}| | 422 | Request validation failed | UnprocessableEntityResponse
Examples
{
"detail": {
"cause": "Invalid request format. The request body could not be parsed.",
"response": "Invalid request format"
}
}{
"detail": {
"cause": "Missing required attributes: ['query', 'model', 'provider']",
"response": "Missing required attributes"
}
}{
"detail": {
"cause": "Invalid attachment type: must be one of ['text/plain', 'application/json', 'application/yaml', 'application/xml']",
"response": "Invalid attribute value"
}
}| | 429 | Quota limit exceeded | QuotaExceededResponse
Examples
{
"detail": {
"cause": "The token quota for model gpt-4-turbo has been exceeded.",
"response": "The model quota has been exceeded"
}
}{
"detail": {
"cause": "User 123 has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Cluster has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Unknown subject 999 has no available tokens.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "User 123 has 5 tokens, but 10 tokens are needed.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Cluster has 500 tokens, but 900 tokens are needed.",
"response": "The quota has been exceeded"
}
}{
"detail": {
"cause": "Unknown subject 999 has 3 tokens, but 6 tokens are needed.",
"response": "The quota has been exceeded"
}
}| | 500 | Internal server error | InternalServerErrorResponse | | 503 | Service unavailable | ServiceUnavailableResponse
Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}|
Readiness Probe Get Method
Handle the readiness probe endpoint, returning service readiness.
If any provider reports an error status, responds with HTTP 503 and details of unhealthy providers; otherwise, indicates the service is ready.
Returns:
ReadinessResponse: Object with ready indicating overall readiness,
reason explaining the outcome, and providers containing the list of
unhealthy ProviderHealthStatus entries (empty when ready).
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | ReadinessResponse |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}| | 503 | Service unavailable | ServiceUnavailableResponse
Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}|
Liveness Probe Get Method
Return the liveness status of the service.
Returns: LivenessResponse: Indicates that the service is alive.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | LivenessResponse |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}|
Authorized Endpoint Handler
Handle request to the /authorized endpoint.
Process POST requests to the /authorized endpoint, returning the authenticated user's ID and username.
The response intentionally omits any authentication token.
Returns: AuthorizedResponse: Contains the user ID and username of the authenticated user.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful response | AuthorizedResponse |
| 401 | Unauthorized | UnauthorizedResponse |
Examples
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}| | 403 | Permission denied | ForbiddenResponse
Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}|
Metrics Endpoint Handler
Handle request to the /metrics endpoint.
Process GET requests to the /metrics endpoint, returning the latest Prometheus metrics in form of a plain text.
Initializes model metrics on the first request if not already set up, then responds with the current metrics snapshot in Prometheus format.
Returns: PlainTextResponse: Response body containing the Prometheus metrics text and the Prometheus content type.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful Response | string |
| 401 | Unauthorized | ... |
| Examples |
{
"detail": {
"cause": "No Authorization header found",
"response": "Missing or invalid credentials provided by client"
}
}{
"detail": {
"cause": "No token found in Authorization header",
"response": "Missing or invalid credentials provided by client"
}
}UnauthorizedResponse | | 403 | Permission denied | ... Examples
{
"detail": {
"cause": "User 6789 is not authorized to access this endpoint.",
"response": "User does not have permission to access this endpoint"
}
}ForbiddenResponse | | 500 | Internal server error | ... Examples
{
"detail": {
"cause": "Lightspeed Stack configuration has not been initialized.",
"response": "Configuration is not loaded"
}
}InternalServerErrorResponse | | 503 | Service unavailable | ... Examples
{
"detail": {
"cause": "Connection error while trying to reach backend service.",
"response": "Unable to connect to Llama Stack"
}
}Get Agent Card
Serve the A2A Agent Card at the well-known location.
This endpoint provides the agent card that describes Lightspeed's capabilities according to the A2A protocol specification.
Returns: AgentCard: The agent card describing this agent's capabilities.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful Response | AgentCard |
Get Agent Card
Serve the A2A Agent Card at the well-known location.
This endpoint provides the agent card that describes Lightspeed's capabilities according to the A2A protocol specification.
Returns: AgentCard: The agent card describing this agent's capabilities.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful Response | AgentCard |
Handle A2A Jsonrpc
Handle A2A JSON-RPC requests following the A2A protocol specification.
This endpoint uses the DefaultRequestHandler from the A2A SDK to handle all JSON-RPC requests including message/send, message/stream, etc.
The A2A SDK application is created per-request to include authentication context while still leveraging FastAPI's authorization middleware.
Automatically detects streaming requests (message/stream JSON-RPC method) and returns a StreamingResponse to enable real-time chunk delivery.
Args: request: FastAPI request object auth: Authentication tuple mcp_headers: MCP headers for context propagation
Returns: JSON-RPC response or streaming response
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful Response | ... |
Handle A2A Jsonrpc
Handle A2A JSON-RPC requests following the A2A protocol specification.
This endpoint uses the DefaultRequestHandler from the A2A SDK to handle all JSON-RPC requests including message/send, message/stream, etc.
The A2A SDK application is created per-request to include authentication context while still leveraging FastAPI's authorization middleware.
Automatically detects streaming requests (message/stream JSON-RPC method) and returns a StreamingResponse to enable real-time chunk delivery.
Args: request: FastAPI request object auth: Authentication tuple mcp_headers: MCP headers for context propagation
Returns: JSON-RPC response or streaming response
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful Response | ... |
A2A Health Check
Health check endpoint for A2A service.
Returns: Dict with health status information.
| Status Code | Description | Component |
|---|---|---|
| 200 | Successful Response | object |
A2A protocol persistent state configuration.
Configures how A2A task state and context-to-conversation mappings are stored. For multi-worker deployments, use SQLite or PostgreSQL to ensure state is shared across all workers.
If no configuration is provided, in-memory storage is used (default). This is suitable for single-worker deployments but state will be lost on restarts and not shared across workers.
Attributes: sqlite: SQLite database configuration for A2A state storage. postgres: PostgreSQL database configuration for A2A state storage.
| Field | Type | Description |
|---|---|---|
| sqlite | SQLite database configuration for A2A state storage. | |
| postgres | PostgreSQL database configuration for A2A state storage. |
Defines a security scheme using an API key.
| Field | Type | Description |
|---|---|---|
| description | ||
| in | ||
| name | string | |
| type | string |
API Key Token configuration.
| Field | Type | Description |
|---|---|---|
| api_key | string |
Rule defining what actions a role can perform.
| Field | Type | Description |
|---|---|---|
| role | string | Name of the role |
| actions | array | Allowed actions for this role |
Available actions in the system.
Note: this is not a real model, just an enumeration of all action names.
Defines optional capabilities supported by an agent.
| Field | Type | Description |
|---|---|---|
| extensions | ||
| pushNotifications | ||
| stateTransitionHistory | ||
| streaming |
The AgentCard is a self-describing manifest for an agent. It provides essential metadata including the agent's identity, capabilities, skills, supported communication methods, and security requirements.
| Field | Type | Description |
|---|---|---|
| additionalInterfaces | ||
| capabilities | ||
| defaultInputModes | array | |
| defaultOutputModes | array | |
| description | string | |
| documentationUrl | ||
| iconUrl | ||
| name | string | |
| preferredTransport | ||
| protocolVersion | ||
| provider | ||
| security | ||
| securitySchemes | ||
| signatures | ||
| skills | array | |
| supportsAuthenticatedExtendedCard | ||
| url | string | |
| version | string |
AgentCardSignature represents a JWS signature of an AgentCard. This follows the JSON format of an RFC 7515 JSON Web Signature (JWS).
| Field | Type | Description |
|---|---|---|
| header | ||
| protected | string | |
| signature | string |
A declaration of a protocol extension supported by an Agent.
| Field | Type | Description |
|---|---|---|
| description | ||
| params | ||
| required | ||
| uri | string |
Declares a combination of a target URL and a transport protocol for interacting with the agent. This allows agents to expose the same functionality over multiple transport mechanisms.
| Field | Type | Description |
|---|---|---|
| transport | string | |
| url | string |
Represents the service provider of an agent.
| Field | Type | Description |
|---|---|---|
| organization | string | |
| url | string |
Represents a distinct capability or function that an agent can perform.
| Field | Type | Description |
|---|---|---|
| description | string | |
| examples | ||
| id | string | |
| inputModes | ||
| name | string | |
| outputModes | ||
| security | ||
| tags | array |
Model representing an attachment that can be send from the UI as part of query.
A list of attachments can be an optional part of 'query' request.
Attributes: attachment_type: The attachment type, like "log", "configuration" etc. content_type: The content type as defined in MIME standard content: The actual attachment content
YAML attachments with kind and metadata/name attributes will be handled as resources with the specified name:
kind: Pod
metadata:
name: private-reg
| Field | Type | Description |
|---|---|---|
| attachment_type | string | The attachment type, like 'log', 'configuration' etc. |
| content_type | string | The content type as defined in MIME standard |
| content | string | The actual attachment content |
Authentication configuration.
| Field | Type | Description |
|---|---|---|
| module | string | |
| skip_tls_verification | boolean | |
| skip_for_health_probes | boolean | Skip authorization for readiness and liveness probes |
| k8s_cluster_api | ||
| k8s_ca_cert_path | ||
| jwk_config | ||
| api_key_config | ||
| rh_identity_config |
Defines configuration details for the OAuth 2.0 Authorization Code flow.
| Field | Type | Description |
|---|---|---|
| authorizationUrl | string | |
| refreshUrl | ||
| scopes | object | |
| tokenUrl | string |
Authorization configuration.
| Field | Type | Description |
|---|---|---|
| access_rules | array | Rules for role-based access control |
Model representing a response to an authorization request.
Attributes: user_id: The ID of the logged in user. username: The name of the logged in user. skip_userid_check: Whether to skip the user ID check.
| Field | Type | Description |
|---|---|---|
| user_id | string | User ID, for example UUID |
| username | string | User name |
| skip_userid_check | boolean | Whether to skip the user ID check |
Microsoft Entra ID authentication attributes for Azure.
| Field | Type | Description |
|---|---|---|
| tenant_id | string | |
| client_id | string | |
| client_secret | string | |
| scope | string | Azure Cognitive Services scope for token requests. Override only if using a different Azure service. |
400 Bad Request. Invalid resource identifier.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
BYOK (Bring Your Own Knowledge) RAG configuration.
| Field | Type | Description |
|---|---|---|
| rag_id | string | Unique RAG ID |
| rag_type | string | Type of RAG database. |
| embedding_model | string | Embedding model identification |
| embedding_dimension | integer | Dimensionality of embedding vectors. |
| vector_db_id | string | Vector database identification. |
| db_path | string | Path to RAG database. |
CORS configuration.
CORS or 'Cross-Origin Resource Sharing' refers to the situations when a frontend running in a browser has JavaScript code that communicates with a backend, and the backend is in a different 'origin' than the frontend.
Useful resources:
| Field | Type | Description |
|---|---|---|
| allow_origins | array | A list of origins allowed for cross-origin requests. An origin is the combination of protocol (http, https), domain (myapp.com, localhost, localhost.tiangolo.com), and port (80, 443, 8080). Use ['*'] to allow all origins. |
| allow_credentials | boolean | Indicate that cookies should be supported for cross-origin requests |
| allow_methods | array | A list of HTTP methods that should be allowed for cross-origin requests. You can use ['*'] to allow all standard methods. |
| allow_headers | array | A list of HTTP request headers that should be supported for cross-origin requests. You can use ['*'] to allow all headers. The Accept, Accept-Language, Content-Language and Content-Type headers are always allowed for simple CORS requests. |
Defines configuration details for the OAuth 2.0 Client Credentials flow.
| Field | Type | Description |
|---|---|---|
| refreshUrl | ||
| scopes | object | |
| tokenUrl | string |
Global service configuration.
| Field | Type | Description |
|---|---|---|
| name | string | Name of the service. That value will be used in REST API endpoints. |
| service | This section contains Lightspeed Core Stack service configuration. | |
| llama_stack | This section contains Llama Stack configuration. Lightspeed Core Stack service can call Llama Stack in library mode or in server mode. | |
| user_data_collection | This section contains configuration for subsystem that collects user data(transcription history and feedbacks). | |
| database | Configuration for database to store conversation IDs and other runtime data | |
| mcp_servers | array | MCP (Model Context Protocol) servers provide tools and capabilities to the AI agents. These are configured in this section. Only MCP servers defined in the lightspeed-stack.yaml configuration are available to the agents. Tools configured in the llama-stack run.yaml are not accessible to lightspeed-core agents. |
| authentication | Authentication configuration | |
| authorization | Lightspeed Core Stack implements a modular authentication and authorization system with multiple authentication methods. Authorization is configurable through role-based access control. Authentication is handled through selectable modules configured via the module field in the authentication configuration. | |
| customization | It is possible to customize Lightspeed Core Stack via this section. System prompt can be customized and also different parts of the service can be replaced by custom Python modules. | |
| inference | One LLM provider and one its model might be selected as default ones. When no provider+model pair is specified in REST API calls (query endpoints), the default provider and model are used. | |
| conversation_cache | ||
| byok_rag | array | BYOK RAG configuration. This configuration can be used to reconfigure Llama Stack through its run.yaml configuration file |
| a2a_state | Configuration for A2A protocol persistent state storage. | |
| quota_handlers | Quota handlers configuration | |
| azure_entra_id | ||
| splunk | Splunk HEC configuration for sending telemetry events. | |
| deployment_environment | string | Deployment environment name (e.g., 'development', 'staging', 'production'). Used in telemetry events. |
| solr | Configuration for Solr vector search operations. |
Success response model for the config endpoint.
| Field | Type | Description |
|---|---|---|
| configuration |
Model representing conversation data returned by cache list operations.
Attributes: conversation_id: The conversation ID topic_summary: The topic summary for the conversation (can be None) last_message_timestamp: The timestamp of the last message in the conversation
| Field | Type | Description |
|---|---|---|
| conversation_id | string | |
| topic_summary | ||
| last_message_timestamp | number |
Model representing a response for deleting a conversation.
Attributes: conversation_id: The conversation ID (UUID) that was deleted. success: Whether the deletion was successful. response: A message about the deletion result.
| Field | Type | Description |
|---|---|---|
| conversation_id | string | The conversation ID (UUID) that was deleted. |
| success | boolean | Whether the deletion was successful. |
| response | string | A message about the deletion result. |
Model representing the details of a user conversation.
Attributes: conversation_id: The conversation ID (UUID). created_at: When the conversation was created. last_message_at: When the last message was sent. message_count: Number of user messages in the conversation. last_used_model: The last model used for the conversation. last_used_provider: The provider of the last used model. topic_summary: The topic summary for the conversation.
Example:
python conversation = ConversationDetails( conversation_id="123e4567-e89b-12d3-a456-426614174000", created_at="2024-01-01T00:00:00Z", last_message_at="2024-01-01T00:05:00Z", message_count=5, last_used_model="gemini/gemini-2.0-flash", last_used_provider="gemini", topic_summary="Openshift Microservices Deployment Strategies", )
| Field | Type | Description |
|---|---|---|
| conversation_id | string | Conversation ID (UUID) |
| created_at | When the conversation was created | |
| last_message_at | When the last message was sent | |
| message_count | Number of user messages in the conversation | |
| last_used_model | Identification of the last model used for the conversation | |
| last_used_provider | Identification of the last provider used for the conversation | |
| topic_summary | Topic summary for the conversation |
Conversation history configuration.
| Field | Type | Description |
|---|---|---|
| type | Type of database where the conversation history is to be stored. | |
| memory | In-memory cache configuration | |
| sqlite | SQLite database configuration | |
| postgres | PostgreSQL database configuration |
Model representing a response for retrieving a conversation.
Attributes: conversation_id: The conversation ID (UUID). chat_history: The chat history as a list of conversation turns.
| Field | Type | Description |
|---|---|---|
| conversation_id | string | Conversation ID (UUID) |
| chat_history | array | The simplified chat history as a list of conversation turns |
Model representing a single conversation turn.
Attributes: messages: List of messages in this turn. tool_calls: List of tool calls made in this turn. tool_results: List of tool results from this turn. provider: Provider identifier used for this turn. model: Model identifier used for this turn. started_at: ISO 8601 timestamp when the turn started. completed_at: ISO 8601 timestamp when the turn completed.
| Field | Type | Description |
|---|---|---|
| messages | array | List of messages in this turn |
| tool_calls | array | List of tool calls made in this turn |
| tool_results | array | List of tool results from this turn |
| provider | string | Provider identifier used for this turn |
| model | string | Model identifier used for this turn |
| started_at | string | ISO 8601 timestamp when the turn started |
| completed_at | string | ISO 8601 timestamp when the turn completed |
Model representing a request to update a conversation topic summary.
Attributes: topic_summary: The new topic summary for the conversation.
Example:
python update_request = ConversationUpdateRequest( topic_summary="Discussion about machine learning algorithms" )
| Field | Type | Description |
|---|---|---|
| topic_summary | string | The new topic summary for the conversation |
Model representing a response for updating a conversation topic summary.
Attributes: conversation_id: The conversation ID (UUID) that was updated. success: Whether the update was successful. message: A message about the update result.
Example:
python update_response = ConversationUpdateResponse( conversation_id="123e4567-e89b-12d3-a456-426614174000", success=True, message="Topic summary updated successfully", )
| Field | Type | Description |
|---|---|---|
| conversation_id | string | The conversation ID (UUID) that was updated |
| success | boolean | Whether the update was successful |
| message | string | A message about the update result |
Model representing a response for listing conversations of a user.
Attributes: conversations: List of conversation details associated with the user.
| Field | Type | Description |
|---|---|---|
| conversations | array |
Model representing a response for listing conversations of a user.
Attributes: conversations: List of conversation data associated with the user.
| Field | Type | Description |
|---|---|---|
| conversations | array |
Custom profile customization for prompts and validation.
| Field | Type | Description |
|---|---|---|
| path | string | Path to Python modules containing custom profile. |
| prompts | object | Dictionary containing map of system prompts |
Service customization.
| Field | Type | Description |
|---|---|---|
| profile_path | ||
| disable_query_system_prompt | boolean | |
| disable_shield_ids_override | boolean | |
| system_prompt_path | ||
| system_prompt | ||
| agent_card_path | ||
| agent_card_config | ||
| custom_profile |
Database configuration.
| Field | Type | Description |
|---|---|---|
| sqlite | SQLite database configuration | |
| postgres | PostgreSQL database configuration |
Nested detail model for error responses.
| Field | Type | Description |
|---|---|---|
| response | string | Short summary of the error |
| cause | string | Detailed explanation of what caused the error |
Enum representing predefined feedback categories for AI responses.
These categories help provide structured feedback about AI inference quality when users provide negative feedback (thumbs down). Multiple categories can be selected to provide comprehensive feedback about response issues.
Model representing a feedback request.
Attributes: conversation_id: The required conversation ID (UUID). user_question: The required user question. llm_response: The required LLM response. sentiment: The optional sentiment. user_feedback: The optional user feedback. categories: The optional list of feedback categories (multi-select for negative feedback).
Example:
python feedback_request = FeedbackRequest( conversation_id="12345678-abcd-0000-0123-456789abcdef", user_question="what are you doing?", user_feedback="This response is not helpful", llm_response="I don't know", sentiment=-1, categories=[FeedbackCategory.INCORRECT, FeedbackCategory.INCOMPLETE] )
| Field | Type | Description |
|---|---|---|
| conversation_id | string | The required conversation ID (UUID) |
| user_question | string | User question (the query string) |
| llm_response | string | Response from LLM |
| sentiment | User sentiment, if provided must be -1 or 1 | |
| user_feedback | Feedback on the LLM response. | |
| categories | List of feedback categories that describe issues with the LLM response (for negative feedback). |
Model representing a response to a feedback request.
Attributes: response: The response of the feedback request.
Example:
python feedback_response = FeedbackResponse(response="feedback received")
| Field | Type | Description |
|---|---|---|
| response | string | The response of the feedback request. |
Model representing a feedback status update request.
Attributes: status: Value of the desired feedback enabled state.
Example:
python feedback_request = FeedbackRequest( status=false )
| Field | Type | Description |
|---|---|---|
| status | boolean | Desired state of feedback enablement, must be False or True |
Model representing a response to a feedback status update request.
Attributes: status: The previous and current status of the service and who updated it.
Example:
python status_response = StatusResponse( status={ "previous_status": true, "updated_status": false, "updated_by": "user/test", "timestamp": "2023-03-15 12:34:56" }, )
| Field | Type | Description |
|---|---|---|
| status | object |
403 Forbidden. Access denied.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
Defines a security scheme using HTTP authentication.
| Field | Type | Description |
|---|---|---|
| bearerFormat | ||
| description | ||
| scheme | string | |
| type | string |
| Field | Type | Description |
|---|---|---|
| detail | array |
Defines configuration details for the OAuth 2.0 Implicit flow.
| Field | Type | Description |
|---|---|---|
| authorizationUrl | string | |
| refreshUrl | ||
| scopes | object |
The location of the API key.
In-memory cache configuration.
| Field | Type | Description |
|---|---|---|
| max_entries | integer | Maximum number of entries stored in the in-memory cache |
Inference configuration.
| Field | Type | Description |
|---|---|---|
| default_model | Identification of default model used when no other model is specified. | |
| default_provider | Identification of default provider used when no other model is specified. |
Model representing a response to an info request.
Attributes: name: Service name. service_version: Service version. llama_stack_version: Llama Stack version.
Example:
python info_response = InfoResponse( name="Lightspeed Stack", service_version="1.0.0", llama_stack_version="0.2.22", )
| Field | Type | Description |
|---|---|---|
| name | string | Service name |
| service_version | string | Service version |
| llama_stack_version | string | Llama Stack version |
500 Internal Server Error.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
Supported operators for JSONPath evaluation.
Note: this is not a real model, just an enumeration of all supported JSONPath operators.
JWK (JSON Web Key) configuration.
A JSON Web Key (JWK) is a JavaScript Object Notation (JSON) data structure that represents a cryptographic key.
Useful resources:
| Field | Type | Description |
|---|---|---|
| url | string | HTTPS URL of the JWK (JSON Web Key) set used to validate JWTs. |
| jwt_configuration | JWT (JSON Web Token) configuration |
JWT (JSON Web Token) configuration.
JSON Web Token (JWT) is a compact, URL-safe means of representing claims to be transferred between two parties. The claims in a JWT are encoded as a JSON object that is used as the payload of a JSON Web Signature (JWS) structure or as the plaintext of a JSON Web Encryption (JWE) structure, enabling the claims to be digitally signed or integrity protected with a Message Authentication Code (MAC) and/or encrypted.
Useful resources:
| Field | Type | Description |
|---|---|---|
| user_id_claim | string | JWT claim name that uniquely identifies the user (subject ID). |
| username_claim | string | JWT claim name that provides the human-readable username. |
| role_rules | array | Rules for extracting roles from JWT claims |
Rule for extracting roles from JWT claims.
| Field | Type | Description |
|---|---|---|
| jsonpath | string | JSONPath expression to evaluate against the JWT payload |
| operator | JSON path comparison operator | |
| negate | boolean | If set to true, the meaning of the rule is negated |
| value | Value to compare against | |
| roles | array | Roles to be assigned if the rule matches |
Model representing a response to a liveness request.
Attributes: alive: If app is alive.
Example:
python liveness_response = LivenessResponse(alive=True)
| Field | Type | Description |
|---|---|---|
| alive | boolean | Flag indicating that the app is alive |
Llama stack configuration.
Llama Stack is a comprehensive system that provides a uniform set of tools for building, scaling, and deploying generative AI applications, enabling developers to create, integrate, and orchestrate multiple AI services and capabilities into an adaptable setup.
Useful resources:
| Field | Type | Description |
|---|---|---|
| url | URL to Llama Stack service; used when library mode is disabled. Must be a valid HTTP or HTTPS URL. | |
| api_key | API key to access Llama Stack service | |
| use_as_library_client | When set to true Llama Stack will be used in library mode, not in server mode (default) | |
| library_client_config_path | Path to configuration file used when Llama Stack is run in library mode | |
| timeout | integer | Timeout in seconds for requests to Llama Stack service. Default is 180 seconds (3 minutes) to accommodate long-running RAG queries. |
Response containing MCP servers that accept client-provided authorization.
| Field | Type | Description |
|---|---|---|
| servers | array | List of MCP servers that accept client-provided authorization |
Information about MCP server client authentication options.
| Field | Type | Description |
|---|---|---|
| name | string | MCP server name |
| client_auth_headers | array | List of authentication header names for client-provided tokens |
Model representing a message in a conversation turn.
Attributes: content: The message content. type: The type of message.
| Field | Type | Description |
|---|---|---|
| content | string | The message content |
| type | string | The type of message |
Model context protocol server configuration.
MCP (Model Context Protocol) servers provide tools and capabilities to the AI agents. These are configured by this structure. Only MCP servers defined in the lightspeed-stack.yaml configuration are available to the agents. Tools configured in the llama-stack run.yaml are not accessible to lightspeed-core agents.
Useful resources:
| Field | Type | Description |
|---|---|---|
| name | string | MCP server name that must be unique |
| provider_id | string | MCP provider identification |
| url | string | URL of the MCP server |
| authorization_headers | object | Headers to send to the MCP server. The map contains the header name and the path to a file containing the header value (secret). There are 3 special cases: 1. Usage of the kubernetes token in the header. To specify this use a string 'kubernetes' instead of the file path. 2. Usage of the client-provided token in the header. To specify this use a string 'client' instead of the file path. 3. Usage of the oauth token in the header. To specify this use a string 'oauth' instead of the file path. |
| timeout | Timeout in seconds for requests to the MCP server. If not specified, the default timeout from Llama Stack will be used. Note: This field is reserved for future use when Llama Stack adds timeout support. |
Model representing a response to models request.
| Field | Type | Description |
|---|---|---|
| models | array | List of models available |
Defines a security scheme using mTLS authentication.
| Field | Type | Description |
|---|---|---|
| description | ||
| type | string |
404 Not Found - Resource does not exist.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
Defines a security scheme using OAuth 2.0.
| Field | Type | Description |
|---|---|---|
| description | ||
| flows | ||
| oauth2MetadataUrl | ||
| type | string |
Defines the configuration for the supported OAuth 2.0 flows.
| Field | Type | Description |
|---|---|---|
| authorizationCode | ||
| clientCredentials | ||
| implicit | ||
| password |
Defines a security scheme using OpenID Connect.
| Field | Type | Description |
|---|---|---|
| description | ||
| openIdConnectUrl | string | |
| type | string |
Defines configuration details for the OAuth 2.0 Resource Owner Password flow.
| Field | Type | Description |
|---|---|---|
| refreshUrl | ||
| scopes | object | |
| tokenUrl | string |
PostgreSQL database configuration.
PostgreSQL database is used by Lightspeed Core Stack service for storing information about conversation IDs. It can also be leveraged to store conversation history and information about quota usage.
Useful resources:
| Field | Type | Description |
|---|---|---|
| host | string | Database server host or socket directory |
| port | integer | Database server port |
| db | string | Database name to connect to |
| user | string | Database user name used to authenticate |
| password | string | Password used to authenticate |
| namespace | Database namespace | |
| ssl_mode | string | SSL mode |
| gss_encmode | string | This option determines whether or with what priority a secure GSS TCP/IP connection will be negotiated with the server. |
| ca_cert_path | Path to CA certificate |
413 Payload Too Large - Prompt is too long.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
Model representing the health status of a provider.
Attributes: provider_id: The ID of the provider. status: The health status ('ok', 'unhealthy', 'not_implemented'). message: Optional message about the health status.
| Field | Type | Description |
|---|---|---|
| provider_id | string | The ID of the provider |
| status | string | The health status |
| message | Optional message about the health status |
Model representing a response to get specific provider request.
| Field | Type | Description |
|---|---|---|
| api | string | The API this provider implements |
| config | object | Provider configuration parameters |
| health | object | Current health status of the provider |
| provider_id | string | Unique provider identifier |
| provider_type | string | Provider implementation type |
Model representing a response to providers request.
| Field | Type | Description |
|---|---|---|
| providers | object | List of available API types and their corresponding providers |
Model representing a request for the LLM (Language Model).
Attributes: query: The query string. conversation_id: The optional conversation ID (UUID). provider: The optional provider. model: The optional model. system_prompt: The optional system prompt. attachments: The optional attachments. no_tools: Whether to bypass all tools and MCP servers (default: False). generate_topic_summary: Whether to generate topic summary for new conversations. media_type: The optional media type for response format (application/json or text/plain). vector_store_ids: The optional list of specific vector store IDs to query for RAG. shield_ids: The optional list of safety shield IDs to apply.
Example:
python query_request = QueryRequest(query="Tell me about Kubernetes")
| Field | Type | Description |
|---|---|---|
| query | string | The query string |
| conversation_id | The optional conversation ID (UUID) | |
| provider | The optional provider | |
| model | The optional model | |
| system_prompt | The optional system prompt. | |
| attachments | The optional list of attachments. | |
| no_tools | Whether to bypass all tools and MCP servers | |
| generate_topic_summary | Whether to generate topic summary for new conversations | |
| media_type | Media type for the response format | |
| vector_store_ids | Optional list of specific vector store IDs to query for RAG. If not provided, all available vector stores will be queried. | |
| shield_ids | Optional list of safety shield IDs to apply. If None, all configured shields are used. If provided, must contain at least one valid shield ID (empty list raises 422 error). | |
| solr | Solr-specific query parameters including filter queries |
Model representing LLM response to a query.
Attributes: conversation_id: The optional conversation ID (UUID). response: The response. rag_chunks: Deprecated. List of RAG chunks used to generate the response. This information is now available in tool_results under file_search_call type. referenced_documents: The URLs and titles for the documents used to generate the response. tool_calls: List of tool calls made during response generation. tool_results: List of tool results. truncated: Whether conversation history was truncated. input_tokens: Number of tokens sent to LLM. output_tokens: Number of tokens received from LLM. available_quotas: Quota available as measured by all configured quota limiters.
| Field | Type | Description |
|---|---|---|
| conversation_id | The optional conversation ID (UUID) | |
| response | string | Response from LLM |
| rag_chunks | array | Deprecated: List of RAG chunks used to generate the response. |
| referenced_documents | array | List of documents referenced in generating the response |
| truncated | boolean | Deprecated:Whether conversation history was truncated |
| input_tokens | integer | Number of tokens sent to LLM |
| output_tokens | integer | Number of tokens received from LLM |
| available_quotas | object | Quota available as measured by all configured quota limiters |
| tool_calls | array | List of tool calls made during response generation |
| tool_results | array | List of tool results |
429 Too Many Requests - Quota limit exceeded.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
Quota limiter configuration.
It is possible to limit quota usage per user or per service or services
(that typically run in one cluster). Each limit is configured as a separate
quota limiter. It can be of type user_limiter or cluster_limiter
(which is name that makes sense in OpenShift deployment).
| Field | Type | Description |
|---|---|---|
| sqlite | SQLite database configuration | |
| postgres | PostgreSQL database configuration | |
| limiters | array | Quota limiters configuration |
| scheduler | Quota scheduler configuration | |
| enable_token_history | boolean | Enables storing information about token usage history |
Configuration for one quota limiter.
There are three configuration options for each limiter:
periodis specified in a human-readable form, see https://www.postgresql.org/docs/current/datatype-datetime.html#DATATYPE-INTERVAL-INPUT for all possible options. When the end of the period is reached, the quota is reset or increased.initial_quotais the value set at the beginning of the period.quota_increaseis the value (if specified) used to increase the quota when the period is reached.
There are two basic use cases:
- When the quota needs to be reset to a specific value periodically (for
example on a weekly or monthly basis), set
initial_quotato the required value. - When the quota needs to be increased by a specific value periodically
(for example on a daily basis), set
quota_increase.
| Field | Type | Description |
|---|---|---|
| type | string | Quota limiter type, either user_limiter or cluster_limiter |
| name | string | Human readable quota limiter name |
| initial_quota | integer | Quota set at beginning of the period |
| quota_increase | integer | Delta value used to increase quota when period is reached |
| period | string | Period specified in human readable form |
Quota scheduler configuration.
| Field | Type | Description |
|---|---|---|
| period | integer | Quota scheduler period specified in seconds |
| database_reconnection_count | integer | Database reconnection count on startup. When database for quota is not available on startup, the service tries to reconnect N times with specified delay. |
| database_reconnection_delay | integer | Database reconnection delay specified in seconds. When database for quota is not available on startup, the service tries to reconnect N times with specified delay. |
Model representing a RAG chunk used in the response.
| Field | Type | Description |
|---|---|---|
| content | string | The content of the chunk |
| source | Index name identifying the knowledge source from configuration | |
| score | Relevance score | |
| attributes | Document metadata from the RAG provider (e.g., url, title, author) |
Model representing a response with information about RAG DB.
| Field | Type | Description |
|---|---|---|
| id | string | Vector DB unique ID |
| name | Human readable vector DB name | |
| created_at | integer | When the vector store was created, represented as Unix time |
| last_active_at | When the vector store was last active, represented as Unix time | |
| usage_bytes | integer | Storage byte(s) used by this vector DB |
| expires_at | When the vector store expires, represented as Unix time | |
| object | string | Object type |
| status | string | Vector DB status |
Model representing a response to list RAGs request.
| Field | Type | Description |
|---|---|---|
| rags | array | List of RAG identifiers |
Red Hat Identity authentication configuration.
| Field | Type | Description |
|---|---|---|
| required_entitlements | List of all required entitlements. |
Model representing response to a readiness request.
Attributes: ready: If service is ready. reason: The reason for the readiness. providers: List of unhealthy providers in case of readiness failure.
Example:
python readiness_response = ReadinessResponse( ready=False, reason="Service is not ready", providers=[ ProviderHealthStatus( provider_id="ollama", status="unhealthy", message="Server is unavailable" ) ] )
| Field | Type | Description |
|---|---|---|
| ready | boolean | Flag indicating if service is ready |
| reason | string | The reason for the readiness |
| providers | array | List of unhealthy providers in case of readiness failure. |
Model representing a document referenced in generating a response.
Attributes: doc_url: Url to the referenced doc. doc_title: Title of the referenced doc.
| Field | Type | Description |
|---|---|---|
| doc_url | URL of the referenced document | |
| doc_title | Title of the referenced document | |
| source | Index name identifying the knowledge source from configuration |
Attachment data from rlsapi v1 context.
Attributes: contents: The textual contents of the file read on the client machine. mimetype: The MIME type of the file.
| Field | Type | Description |
|---|---|---|
| contents | string | File contents read on client |
| mimetype | string | MIME type of the file |
Command Line Assistant information from rlsapi v1 context.
Attributes: nevra: The NEVRA (Name-Epoch-Version-Release-Architecture) of the CLA. version: The version of the command line assistant.
| Field | Type | Description |
|---|---|---|
| nevra | string | CLA NEVRA identifier |
| version | string | Command line assistant version |
Context data for rlsapi v1 /infer request.
Attributes: stdin: Redirect input read by command-line-assistant. attachments: Attachment object received by the client. terminal: Terminal object received by the client. systeminfo: System information object received by the client. cla: Command Line Assistant information.
| Field | Type | Description |
|---|---|---|
| stdin | string | Redirect input from stdin |
| attachments | File attachment data | |
| terminal | Terminal output context | |
| systeminfo | Client system information | |
| cla | Command line assistant metadata |
Response data for rlsapi v1 /infer endpoint.
Attributes: text: The generated response text. request_id: Unique identifier for the request.
| Field | Type | Description |
|---|---|---|
| text | string | Generated response text |
| request_id | Unique request identifier |
RHEL Lightspeed rlsapi v1 /infer request.
Attributes: question: User question string. context: Context with system info, terminal output, etc. (defaults provided). skip_rag: Reserved for future use. RAG retrieval is not yet implemented.
Example:
python request = RlsapiV1InferRequest( question="How do I list files?", context=RlsapiV1Context( systeminfo=RlsapiV1SystemInfo(os="RHEL", version="9.3"), terminal=RlsapiV1Terminal(output="bash: command not found"), ), )
| Field | Type | Description |
|---|---|---|
| question | string | User question |
| context | Optional context (system info, terminal output, stdin, attachments) | |
| skip_rag | boolean | Reserved for future use. RAG retrieval is not yet implemented. |
RHEL Lightspeed rlsapi v1 /infer response.
Attributes: data: Response data containing text and request_id.
| Field | Type | Description |
|---|---|---|
| data | Response data containing text and request_id |
System information from rlsapi v1 context.
Attributes: os: The operating system of the client machine. version: The version of the operating system. arch: The architecture of the client machine. system_id: The id of the client machine.
| Field | Type | Description |
|---|---|---|
| os | string | Operating system name |
| version | string | Operating system version |
| arch | string | System architecture |
| id | string | Client machine ID |
Terminal output from rlsapi v1 context.
Attributes: output: The textual contents of the terminal read on the client machine.
| Field | Type | Description |
|---|---|---|
| output | string | Terminal output from client |
SQLite database configuration.
| Field | Type | Description |
|---|---|---|
| db_path | string | Path to file where SQLite database is stored |
Service configuration.
Lightspeed Core Stack is a REST API service that accepts requests on a specified hostname and port. It is also possible to enable authentication and specify the number of Uvicorn workers. When more workers are specified, the service can handle requests concurrently.
| Field | Type | Description |
|---|---|---|
| host | string | Service hostname |
| port | integer | Service port |
| base_url | Externally reachable base URL for the service; needed for A2A support. | |
| auth_enabled | boolean | Enables the authentication subsystem |
| workers | integer | Number of Uvicorn worker processes to start |
| color_log | boolean | Enables colorized logging |
| access_log | boolean | Enables logging of all access information |
| tls_config | Transport Layer Security configuration for HTTPS support | |
| root_path | string | ASGI root path for serving behind a reverse proxy on a subpath |
| cors | Cross-Origin Resource Sharing configuration for cross-domain requests |
503 Backend Unavailable.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
Model representing a response to shields request.
| Field | Type | Description |
|---|---|---|
| shields | array | List of shields available |
Solr configuration for vector search queries.
Controls whether to use offline or online mode when building document URLs from vector search results, and enables/disables Solr vector IO functionality.
| Field | Type | Description |
|---|---|---|
| enabled | boolean | When True, enables Solr vector IO functionality for vector search queries. When False, disables Solr vector search processing. |
| offline | boolean | When True, use parent_id for chunk source URLs. When False, use reference_url for chunk source URLs. |
Splunk HEC (HTTP Event Collector) configuration.
Splunk HEC allows sending events directly to Splunk over HTTP/HTTPS. This configuration is used to send telemetry events for inference requests to the corporate Splunk deployment.
Useful resources:
| Field | Type | Description |
|---|---|---|
| enabled | boolean | Enable or disable Splunk HEC integration. |
| url | Splunk HEC endpoint URL. | |
| token_path | Path to file containing the Splunk HEC authentication token. | |
| index | Target Splunk index for events. | |
| source | string | Event source identifier. |
| timeout | integer | HTTP timeout in seconds for HEC requests. |
| verify_ssl | boolean | Whether to verify SSL certificates for HEC endpoint. |
Model representing a response to a status request.
Attributes: functionality: The functionality of the service. status: The status of the service.
Example:
python status_response = StatusResponse( functionality="feedback", status={"enabled": True}, )
| Field | Type | Description |
|---|---|---|
| functionality | string | The functionality of the service |
| status | object | The status of the service |
TLS configuration.
Transport Layer Security (TLS) is a cryptographic protocol designed to provide communications security over a computer network, such as the Internet. The protocol is widely used in applications such as email, instant messaging, and voice over IP, but its use in securing HTTPS remains the most publicly visible.
Useful resources:
| Field | Type | Description |
|---|---|---|
| tls_certificate_path | SSL/TLS certificate file path for HTTPS support. | |
| tls_key_path | SSL/TLS private key file path for HTTPS support. | |
| tls_key_password | Path to file containing the password to decrypt the SSL/TLS private key. |
Model representing a tool call made during response generation (for tool_calls list).
| Field | Type | Description |
|---|---|---|
| id | string | ID of the tool call |
| name | string | Name of the tool called |
| args | object | Arguments passed to the tool |
| type | string | Type indicator for tool call |
Model representing a result from a tool call (for tool_results list).
| Field | Type | Description |
|---|---|---|
| id | string | ID of the tool call/result, matches the corresponding tool call 'id' |
| status | string | Status of the tool execution (e.g., 'success') |
| content | string | Content/result returned from the tool |
| type | string | Type indicator for tool result |
| round | integer | Round number or step of tool execution |
Model representing a response to tools request.
| Field | Type | Description |
|---|---|---|
| tools | array | List of tools available from all configured MCP servers and built-in toolgroups |
401 Unauthorized - Missing or invalid credentials.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
422 Unprocessable Entity - Request validation failed.
| Field | Type | Description |
|---|---|---|
| status_code | integer | |
| detail |
User data collection configuration.
| Field | Type | Description |
|---|---|---|
| feedback_enabled | boolean | When set to true the user feedback is stored and later sent for analysis. |
| feedback_storage | Path to directory where feedback will be saved for further processing. | |
| transcripts_enabled | boolean | When set to true the conversation history is stored and later sent for analysis. |
| transcripts_storage | Path to directory where conversation history will be saved for further processing. |
| Field | Type | Description |
|---|---|---|
| loc | array | |
| msg | string | |
| type | string | |
| input | ||
| ctx | object |