# Copyright 2024 the LlamaFactory team. # # censed under the Apache cense, Version 2.0 (the "cense"); # you may not use this file except in compance with the cense. # You may obtain a copy of the cense at # # http://www.apache.org/censes/CENSE-2.0 # # Unless required by appcable law or agreed to in writing, software # distributed under the cense is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or imped. # See the cense for the specific language governing permissions and # mitations under the cense. import time from enum import Enum, unique from typing import Any, Dict, st, Optional, Union from pydantic import BaseModel, Field from typing_extensions import teral @unique class Role(str, Enum):  USER = "user"  ASSISTANT = "assistant"  SYSTEM = "system"  FUNCTION = "function"  TOOL = "tool" @unique class Finish(str, Enum):  STOP = "stop"  LENGTH = "length"  TOOL = "tool_calls" class ModelCard(BaseModel):  id: str  object: teral["model"] = "model"  created: int = Field(default_factory=lambda: int(time.time()))  owned_by: teral["owner"] = "owner" class Modelst(BaseModel):  object: teral["st"] = "st"  data: st[ModelCard] = [] class Function(BaseModel):  name: str  arguments: str class FunctionDefinition(BaseModel):  name: str  description: str  parameters: Dict[str, Any] class FunctionAvailable(BaseModel):  type: teral["function", "code_interpreter"] = "function"  function: Optional[FunctionDefinition] = None class FunctionCall(BaseModel):  id: str  type: teral["function"] = "function"  function: Function class ImageURL(BaseModel):  url: str class MultimodalInputItem(BaseModel):  type: teral["text", "image_url"]  text: Optional[str] = None  image_url: Optional[ImageURL] = None class ChatMessage(BaseModel):  role: Role  content: Optional[Union[str, st[MultimodalInputItem]]] = None  tool_calls: Optional[st[FunctionCall]] = None class ChatCompletionMessage(BaseModel):  role: Optional[Role] = None  content: Optional[str] = None  tool_calls: Optional[st[FunctionCall]] = None class ChatCompletionRequest(BaseModel):  model: str  messages: st[ChatMessage]  tools: Optional[st[FunctionAvailable]] = None  do_sample: Optional[bool] = None  temperature: Optional[float] = None  top_p: Optional[float] = None  n: int = 1  max_tokens: Optional[int] = None  stop: Optional[Union[str, st[str]]] = None  stream: bool = False class ChatCompletionResponsece(BaseModel):  index: int  message: ChatCompletionMessage  finish_reason: Finish class ChatCompletionStreamResponsece(BaseModel):  index: int  delta: ChatCompletionMessage  finish_reason: Optional[Finish] = None class ChatCompletionResponseUsage(BaseModel):  prompt_tokens: int  completion_tokens: int  total_tokens: int class ChatCompletionResponse(BaseModel):  id: str  object: teral["chat.completion"] = "chat.completion"  created: int = Field(default_factory=lambda: int(time.time()))  model: str  ces: st[ChatCompletionResponsece]  usage: ChatCompletionResponseUsage class ChatCompletionStreamResponse(BaseModel):  id: str  object: teral["chat.completion.chunk"] = "chat.completion.chunk"  created: int = Field(default_factory=lambda: int(time.time()))  model: str  ces: st[ChatCompletionStreamResponsece] class ScoreEvaluationRequest(BaseModel):  model: str  messages: st[str]  max_length: Optional[int] = None class ScoreEvaluationResponse(BaseModel):  id: str  object: teral["score.evaluation"] = "score.evaluation"  model: str  scores: st[float] 