|
import io |
|
import json |
|
from typing import Optional, Tuple, Union |
|
|
|
|
|
class InMemoryFile(io.BytesIO): |
|
def __init__(self, content: bytes, name: str): |
|
super().__init__(content) |
|
self.name = name |
|
|
|
|
|
def replace_model_in_jsonl( |
|
file_content: Union[bytes, Tuple[str, bytes, str]], new_model_name: str |
|
) -> Optional[InMemoryFile]: |
|
try: |
|
|
|
|
|
if hasattr(file_content, "read"): |
|
file_content_bytes = file_content.read() |
|
elif isinstance(file_content, tuple): |
|
file_content_bytes = file_content[1] |
|
else: |
|
file_content_bytes = file_content |
|
|
|
|
|
if isinstance(file_content_bytes, bytes): |
|
file_content_str = file_content_bytes.decode("utf-8") |
|
else: |
|
file_content_str = file_content_bytes |
|
lines = file_content_str.splitlines() |
|
modified_lines = [] |
|
for line in lines: |
|
|
|
json_object = json.loads(line.strip()) |
|
|
|
|
|
if "body" in json_object: |
|
json_object["body"]["model"] = new_model_name |
|
|
|
|
|
modified_lines.append(json.dumps(json_object)) |
|
|
|
|
|
modified_file_content = "\n".join(modified_lines).encode("utf-8") |
|
return InMemoryFile(modified_file_content, name="modified_file.jsonl") |
|
|
|
except (json.JSONDecodeError, UnicodeDecodeError, TypeError): |
|
return None |
|
|
|
|
|
def _get_router_metadata_variable_name(function_name) -> str: |
|
""" |
|
Helper to return what the "metadata" field should be called in the request data |
|
|
|
For all /thread or /assistant endpoints we need to call this "litellm_metadata" |
|
|
|
For ALL other endpoints we call this "metadata |
|
""" |
|
if "batch" in function_name: |
|
return "litellm_metadata" |
|
else: |
|
return "metadata" |
|
|