mirror of
https://github.com/meta-llama/llama-stack.git
synced 2025-06-27 18:50:41 +00:00
# What does this PR do? - add --version to llama stack CLI - add /version endpoint - run OpenAPI generator for the new endpoint ## Test Plan **CLI** <img width="184" alt="image" src="https://github.com/user-attachments/assets/3acb1d22-453e-4b79-baf6-e98e88d0671c" /> **endpoint** <img width="430" alt="image" src="https://github.com/user-attachments/assets/79cdd670-493b-40cf-8f9e-28a4ac0988ac" /> ## Sources Please link relevant resources if necessary. ## Before submitting - [ ] This PR fixes a typo or improves the docs (you can dismiss the other checks if that's the case). - [ ] Ran pre-commit to handle lint / formatting issues. - [ ] Read the [contributor guideline](https://github.com/meta-llama/llama-stack/blob/main/CONTRIBUTING.md), Pull Request section? - [ ] Updated relevant documentation. - [ ] Wrote necessary unit or integration tests.
49 lines
1.2 KiB
Python
49 lines
1.2 KiB
Python
# Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
# All rights reserved.
|
|
#
|
|
# This source code is licensed under the terms described in the LICENSE file in
|
|
# the root directory of this source tree.
|
|
|
|
from typing import Dict, List, Protocol, runtime_checkable
|
|
|
|
from llama_models.schema_utils import json_schema_type, webmethod
|
|
from pydantic import BaseModel
|
|
|
|
|
|
@json_schema_type
|
|
class ProviderInfo(BaseModel):
|
|
provider_id: str
|
|
provider_type: str
|
|
|
|
|
|
@json_schema_type
|
|
class RouteInfo(BaseModel):
|
|
route: str
|
|
method: str
|
|
provider_types: List[str]
|
|
|
|
|
|
@json_schema_type
|
|
class HealthInfo(BaseModel):
|
|
status: str
|
|
# TODO: add a provider level status
|
|
|
|
|
|
@json_schema_type
|
|
class VersionInfo(BaseModel):
|
|
version: str
|
|
|
|
|
|
@runtime_checkable
|
|
class Inspect(Protocol):
|
|
@webmethod(route="/providers/list", method="GET")
|
|
async def list_providers(self) -> Dict[str, ProviderInfo]: ...
|
|
|
|
@webmethod(route="/routes/list", method="GET")
|
|
async def list_routes(self) -> Dict[str, List[RouteInfo]]: ...
|
|
|
|
@webmethod(route="/health", method="GET")
|
|
async def health(self) -> HealthInfo: ...
|
|
|
|
@webmethod(route="/version", method="GET")
|
|
async def version(self) -> VersionInfo: ...
|