mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-24 16:57:21 +00:00 
			
		
		
		
	# What does this PR do? <!-- Provide a short summary of what this PR does and why. Link to relevant issues if applicable. --> This PR renames categories of llama_stack loggers. This PR aligns logging categories as per the package name, as well as reviews from initial https://github.com/meta-llama/llama-stack/pull/2868. This is a follow up to #3061. <!-- If resolving an issue, uncomment and update the line below --> <!-- Closes #[issue-number] --> Replaces https://github.com/meta-llama/llama-stack/pull/2868 Part of https://github.com/meta-llama/llama-stack/issues/2865 cc @leseb @rhuss Signed-off-by: Mustafa Elbehery <melbeher@redhat.com>
		
			
				
	
	
		
			75 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (c) Meta Platforms, Inc. and affiliates.
 | |
| # All rights reserved.
 | |
| #
 | |
| # This source code is licensed under the terms described in the LICENSE file in
 | |
| # the root directory of this source tree.
 | |
| 
 | |
| from llama_stack.log import get_logger
 | |
| from llama_stack.providers.utils.inference.litellm_openai_mixin import LiteLLMOpenAIMixin
 | |
| from llama_stack.providers.utils.inference.openai_mixin import OpenAIMixin
 | |
| 
 | |
| from .config import OpenAIConfig
 | |
| from .models import MODEL_ENTRIES
 | |
| 
 | |
| logger = get_logger(name=__name__, category="inference::openai")
 | |
| 
 | |
| 
 | |
| #
 | |
| # This OpenAI adapter implements Inference methods using two mixins -
 | |
| #
 | |
| # | Inference Method           | Implementation Source    |
 | |
| # |----------------------------|--------------------------|
 | |
| # | completion                 | LiteLLMOpenAIMixin       |
 | |
| # | chat_completion            | LiteLLMOpenAIMixin       |
 | |
| # | embedding                  | LiteLLMOpenAIMixin       |
 | |
| # | batch_completion           | LiteLLMOpenAIMixin       |
 | |
| # | batch_chat_completion      | LiteLLMOpenAIMixin       |
 | |
| # | openai_completion          | OpenAIMixin              |
 | |
| # | openai_chat_completion     | OpenAIMixin              |
 | |
| # | openai_embeddings          | OpenAIMixin              |
 | |
| #
 | |
| class OpenAIInferenceAdapter(OpenAIMixin, LiteLLMOpenAIMixin):
 | |
|     """
 | |
|     OpenAI Inference Adapter for Llama Stack.
 | |
| 
 | |
|     Note: The inheritance order is important here. OpenAIMixin must come before
 | |
|     LiteLLMOpenAIMixin to ensure that OpenAIMixin.check_model_availability()
 | |
|     is used instead of ModelRegistryHelper.check_model_availability().
 | |
| 
 | |
|     - OpenAIMixin.check_model_availability() queries the OpenAI API to check if a model exists
 | |
|     - ModelRegistryHelper.check_model_availability() (inherited by LiteLLMOpenAIMixin) just returns False and shows a warning
 | |
|     """
 | |
| 
 | |
|     def __init__(self, config: OpenAIConfig) -> None:
 | |
|         LiteLLMOpenAIMixin.__init__(
 | |
|             self,
 | |
|             MODEL_ENTRIES,
 | |
|             litellm_provider_name="openai",
 | |
|             api_key_from_config=config.api_key,
 | |
|             provider_data_api_key_field="openai_api_key",
 | |
|         )
 | |
|         self.config = config
 | |
|         # we set is_openai_compat so users can use the canonical
 | |
|         # openai model names like "gpt-4" or "gpt-3.5-turbo"
 | |
|         # and the model name will be translated to litellm's
 | |
|         # "openai/gpt-4" or "openai/gpt-3.5-turbo" transparently.
 | |
|         # if we do not set this, users will be exposed to the
 | |
|         # litellm specific model names, an abstraction leak.
 | |
|         self.is_openai_compat = True
 | |
| 
 | |
|     # Delegate the client data handling get_api_key method to LiteLLMOpenAIMixin
 | |
|     get_api_key = LiteLLMOpenAIMixin.get_api_key
 | |
| 
 | |
|     def get_base_url(self) -> str:
 | |
|         """
 | |
|         Get the OpenAI API base URL.
 | |
| 
 | |
|         Returns the OpenAI API base URL from the configuration.
 | |
|         """
 | |
|         return self.config.base_url
 | |
| 
 | |
|     async def initialize(self) -> None:
 | |
|         await super().initialize()
 | |
| 
 | |
|     async def shutdown(self) -> None:
 | |
|         await super().shutdown()
 |