Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 19 additions & 8 deletions litellm/proxy/auth/auth_checks.py
Original file line number Diff line number Diff line change
Expand Up @@ -432,16 +432,27 @@ def allowed_route_check_inside_route(

def get_actual_routes(allowed_routes: list) -> list:
actual_routes: list = []

# Convert allowed_routes to tuple for __getitem__ lookup optimization only if it's large,
# but keep as-is for simplicity given behavioral preservation requirements.

# Cache LiteLLMRoutes keys to avoid repeated KeyError handling
routes_dict = LiteLLMRoutes.__members__ # maps names to Enum objects (never raises)
extend_actual_routes = actual_routes.extend
append_actual_routes = actual_routes.append

for route_name in allowed_routes:
try:
route_value = LiteLLMRoutes[route_name].value
if isinstance(route_value, set):
actual_routes.extend(list(route_value))
route_enum = routes_dict.get(route_name)
if route_enum is not None:
value = route_enum.value
# Fast-path: Use extend, avoid list() call for set, always extend over append
# Set: convert to list before extending, but in Python, extend accepts any iterable
if isinstance(value, set):
extend_actual_routes(value)
else:
actual_routes.extend(route_value)

except KeyError:
actual_routes.append(route_name)
extend_actual_routes(value)
else:
append_actual_routes(route_name)
return actual_routes


Expand Down