From 4a52a71956a8d46fcb7294ac71734504bb09bcc2 Mon Sep 17 00:00:00 2001 From: S. Solomon Darnell Date: Fri, 28 Mar 2025 21:52:21 -0500 Subject: two version of R2R are here --- .../proxy/management_endpoints/common_utils.py | 41 ++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 .venv/lib/python3.12/site-packages/litellm/proxy/management_endpoints/common_utils.py (limited to '.venv/lib/python3.12/site-packages/litellm/proxy/management_endpoints/common_utils.py') diff --git a/.venv/lib/python3.12/site-packages/litellm/proxy/management_endpoints/common_utils.py b/.venv/lib/python3.12/site-packages/litellm/proxy/management_endpoints/common_utils.py new file mode 100644 index 00000000..d80a06c5 --- /dev/null +++ b/.venv/lib/python3.12/site-packages/litellm/proxy/management_endpoints/common_utils.py @@ -0,0 +1,41 @@ +from typing import Any, Union + +from litellm.proxy._types import ( + GenerateKeyRequest, + LiteLLM_ManagementEndpoint_MetadataFields_Premium, + LiteLLM_TeamTable, + UserAPIKeyAuth, +) +from litellm.proxy.utils import _premium_user_check + + +def _is_user_team_admin( + user_api_key_dict: UserAPIKeyAuth, team_obj: LiteLLM_TeamTable +) -> bool: + for member in team_obj.members_with_roles: + if ( + member.user_id is not None and member.user_id == user_api_key_dict.user_id + ) and member.role == "admin": + + return True + + return False + + +def _set_object_metadata_field( + object_data: Union[LiteLLM_TeamTable, GenerateKeyRequest], + field_name: str, + value: Any, +) -> None: + """ + Helper function to set metadata fields that require premium user checks + + Args: + object_data: The team data object to modify + field_name: Name of the metadata field to set + value: Value to set for the field + """ + if field_name in LiteLLM_ManagementEndpoint_MetadataFields_Premium: + _premium_user_check() + object_data.metadata = object_data.metadata or {} + object_data.metadata[field_name] = value -- cgit v1.2.3