| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | from enum import Enum | 
					
						
							| 
									
										
										
										
											2024-02-09 15:21:33 +08:00
										 |  |  | from typing import Any, Optional, Union, cast | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-14 01:05:37 +08:00
										 |  |  | from pydantic import BaseModel, Field, field_validator | 
					
						
							| 
									
										
										
										
											2024-02-01 18:11:57 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-06 13:21:13 +08:00
										 |  |  | from core.tools.entities.common_entities import I18nObject | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-29 15:19:14 +08:00
										 |  |  | class ToolLabelEnum(Enum): | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     SEARCH = "search" | 
					
						
							|  |  |  |     IMAGE = "image" | 
					
						
							|  |  |  |     VIDEOS = "videos" | 
					
						
							|  |  |  |     WEATHER = "weather" | 
					
						
							|  |  |  |     FINANCE = "finance" | 
					
						
							|  |  |  |     DESIGN = "design" | 
					
						
							|  |  |  |     TRAVEL = "travel" | 
					
						
							|  |  |  |     SOCIAL = "social" | 
					
						
							|  |  |  |     NEWS = "news" | 
					
						
							|  |  |  |     MEDICAL = "medical" | 
					
						
							|  |  |  |     PRODUCTIVITY = "productivity" | 
					
						
							|  |  |  |     EDUCATION = "education" | 
					
						
							|  |  |  |     BUSINESS = "business" | 
					
						
							|  |  |  |     ENTERTAINMENT = "entertainment" | 
					
						
							|  |  |  |     UTILITIES = "utilities" | 
					
						
							|  |  |  |     OTHER = "other" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-29 15:19:14 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolProviderType(Enum): | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     Enum class for tool provider | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  |     BUILT_IN = "builtin" | 
					
						
							|  |  |  |     WORKFLOW = "workflow" | 
					
						
							|  |  |  |     API = "api" | 
					
						
							|  |  |  |     APP = "app" | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     DATASET_RETRIEVAL = "dataset-retrieval" | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     @classmethod | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     def value_of(cls, value: str) -> "ToolProviderType": | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         """
 | 
					
						
							|  |  |  |         Get value of given mode. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         :param value: mode value | 
					
						
							|  |  |  |         :return: mode | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         for mode in cls: | 
					
						
							|  |  |  |             if mode.value == value: | 
					
						
							|  |  |  |                 return mode | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         raise ValueError(f"invalid mode value {value}") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ApiProviderSchemaType(Enum): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Enum class for api provider schema type. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |     OPENAPI = "openapi" | 
					
						
							|  |  |  |     SWAGGER = "swagger" | 
					
						
							|  |  |  |     OPENAI_PLUGIN = "openai_plugin" | 
					
						
							|  |  |  |     OPENAI_ACTIONS = "openai_actions" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @classmethod | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     def value_of(cls, value: str) -> "ApiProviderSchemaType": | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         """
 | 
					
						
							|  |  |  |         Get value of given mode. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         :param value: mode value | 
					
						
							|  |  |  |         :return: mode | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         for mode in cls: | 
					
						
							|  |  |  |             if mode.value == value: | 
					
						
							|  |  |  |                 return mode | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         raise ValueError(f"invalid mode value {value}") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ApiProviderAuthType(Enum): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Enum class for api provider auth type. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |     NONE = "none" | 
					
						
							|  |  |  |     API_KEY = "api_key" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @classmethod | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     def value_of(cls, value: str) -> "ApiProviderAuthType": | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         """
 | 
					
						
							|  |  |  |         Get value of given mode. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         :param value: mode value | 
					
						
							|  |  |  |         :return: mode | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         for mode in cls: | 
					
						
							|  |  |  |             if mode.value == value: | 
					
						
							|  |  |  |                 return mode | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         raise ValueError(f"invalid mode value {value}") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | class ToolInvokeMessage(BaseModel): | 
					
						
							|  |  |  |     class MessageType(Enum): | 
					
						
							|  |  |  |         TEXT = "text" | 
					
						
							|  |  |  |         IMAGE = "image" | 
					
						
							|  |  |  |         LINK = "link" | 
					
						
							|  |  |  |         BLOB = "blob" | 
					
						
							| 
									
										
										
										
											2024-06-24 15:46:16 +08:00
										 |  |  |         JSON = "json" | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         IMAGE_LINK = "image_link" | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  |         FILE_VAR = "file_var" | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     type: MessageType = MessageType.TEXT | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |         plain text, image url or link url | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  |     message: str | bytes | dict | None = None | 
					
						
							|  |  |  |     meta: dict[str, Any] | None = None | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     save_as: str = "" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | class ToolInvokeMessageBinary(BaseModel): | 
					
						
							|  |  |  |     mimetype: str = Field(..., description="The mimetype of the binary") | 
					
						
							|  |  |  |     url: str = Field(..., description="The url of the binary") | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     save_as: str = "" | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  |     file_var: Optional[dict[str, Any]] = None | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-31 11:58:07 +08:00
										 |  |  | class ToolParameterOption(BaseModel): | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |     value: str = Field(..., description="The value of the option") | 
					
						
							|  |  |  |     label: I18nObject = Field(..., description="The label of the option") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     @field_validator("value", mode="before") | 
					
						
							| 
									
										
										
										
											2024-06-16 09:47:20 +08:00
										 |  |  |     @classmethod | 
					
						
							| 
									
										
										
										
											2024-06-14 01:05:37 +08:00
										 |  |  |     def transform_id_to_str(cls, value) -> str: | 
					
						
							| 
									
										
										
										
											2024-06-16 09:47:20 +08:00
										 |  |  |         if not isinstance(value, str): | 
					
						
							| 
									
										
										
										
											2024-06-14 01:05:37 +08:00
										 |  |  |             return str(value) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             return value | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-03 21:26:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-31 11:58:07 +08:00
										 |  |  | class ToolParameter(BaseModel): | 
					
						
							| 
									
										
										
										
											2024-06-03 21:26:58 +08:00
										 |  |  |     class ToolParameterType(str, Enum): | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         STRING = "string" | 
					
						
							|  |  |  |         NUMBER = "number" | 
					
						
							|  |  |  |         BOOLEAN = "boolean" | 
					
						
							|  |  |  |         SELECT = "select" | 
					
						
							| 
									
										
										
										
											2024-03-08 20:31:13 +08:00
										 |  |  |         SECRET_INPUT = "secret-input" | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  |         FILE = "file" | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     class ToolParameterForm(Enum): | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         SCHEMA = "schema"  # should be set while adding tool | 
					
						
							|  |  |  |         FORM = "form"  # should be set before invoking tool | 
					
						
							|  |  |  |         LLM = "llm"  # will be set by LLM | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     name: str = Field(..., description="The name of the parameter") | 
					
						
							|  |  |  |     label: I18nObject = Field(..., description="The label presented to the user") | 
					
						
							| 
									
										
										
										
											2024-07-11 11:02:58 +08:00
										 |  |  |     human_description: Optional[I18nObject] = Field(None, description="The description presented to the user") | 
					
						
							|  |  |  |     placeholder: Optional[I18nObject] = Field(None, description="The placeholder presented to the user") | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |     type: ToolParameterType = Field(..., description="The type of the parameter") | 
					
						
							|  |  |  |     form: ToolParameterForm = Field(..., description="The form of the parameter, schema/form/llm") | 
					
						
							|  |  |  |     llm_description: Optional[str] = None | 
					
						
							|  |  |  |     required: Optional[bool] = False | 
					
						
							| 
									
										
										
										
											2024-08-26 17:10:54 +08:00
										 |  |  |     default: Optional[Union[float, int, str]] = None | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |     min: Optional[Union[float, int]] = None | 
					
						
							|  |  |  |     max: Optional[Union[float, int]] = None | 
					
						
							| 
									
										
										
										
											2024-02-09 15:21:33 +08:00
										 |  |  |     options: Optional[list[ToolParameterOption]] = None | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     @classmethod | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     def get_simple_instance( | 
					
						
							|  |  |  |         cls, | 
					
						
							|  |  |  |         name: str, | 
					
						
							|  |  |  |         llm_description: str, | 
					
						
							|  |  |  |         type: ToolParameterType, | 
					
						
							|  |  |  |         required: bool, | 
					
						
							|  |  |  |         options: Optional[list[str]] = None, | 
					
						
							|  |  |  |     ) -> "ToolParameter": | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         get a simple tool parameter | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         :param name: the name of the parameter | 
					
						
							|  |  |  |         :param llm_description: the description presented to the LLM | 
					
						
							|  |  |  |         :param type: the type of the parameter | 
					
						
							|  |  |  |         :param required: if the parameter is required | 
					
						
							|  |  |  |         :param options: the options of the parameter | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         """
 | 
					
						
							| 
									
										
										
										
											2024-01-31 11:58:07 +08:00
										 |  |  |         # convert options to ToolParameterOption | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         if options: | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |             options = [ | 
					
						
							|  |  |  |                 ToolParameterOption(value=option, label=I18nObject(en_US=option, zh_Hans=option)) for option in options | 
					
						
							|  |  |  |             ] | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         return cls( | 
					
						
							|  |  |  |             name=name, | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |             label=I18nObject(en_US="", zh_Hans=""), | 
					
						
							|  |  |  |             human_description=I18nObject(en_US="", zh_Hans=""), | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |             type=type, | 
					
						
							|  |  |  |             form=cls.ToolParameterForm.LLM, | 
					
						
							|  |  |  |             llm_description=llm_description, | 
					
						
							|  |  |  |             required=required, | 
					
						
							|  |  |  |             options=options, | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolProviderIdentity(BaseModel): | 
					
						
							|  |  |  |     author: str = Field(..., description="The author of the tool") | 
					
						
							|  |  |  |     name: str = Field(..., description="The name of the tool") | 
					
						
							|  |  |  |     description: I18nObject = Field(..., description="The description of the tool") | 
					
						
							|  |  |  |     icon: str = Field(..., description="The icon of the tool") | 
					
						
							|  |  |  |     label: I18nObject = Field(..., description="The label of the tool") | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     tags: Optional[list[ToolLabelEnum]] = Field( | 
					
						
							|  |  |  |         default=[], | 
					
						
							|  |  |  |         description="The tags of the tool", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | class ToolDescription(BaseModel): | 
					
						
							|  |  |  |     human: I18nObject = Field(..., description="The description presented to the user") | 
					
						
							|  |  |  |     llm: str = Field(..., description="The description presented to the LLM") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolIdentity(BaseModel): | 
					
						
							|  |  |  |     author: str = Field(..., description="The author of the tool") | 
					
						
							|  |  |  |     name: str = Field(..., description="The name of the tool") | 
					
						
							|  |  |  |     label: I18nObject = Field(..., description="The label of the tool") | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     provider: str = Field(..., description="The provider of the tool") | 
					
						
							|  |  |  |     icon: Optional[str] = None | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolCredentialsOption(BaseModel): | 
					
						
							|  |  |  |     value: str = Field(..., description="The value of the option") | 
					
						
							|  |  |  |     label: I18nObject = Field(..., description="The label of the option") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolProviderCredentials(BaseModel): | 
					
						
							|  |  |  |     class CredentialsType(Enum): | 
					
						
							|  |  |  |         SECRET_INPUT = "secret-input" | 
					
						
							|  |  |  |         TEXT_INPUT = "text-input" | 
					
						
							|  |  |  |         SELECT = "select" | 
					
						
							| 
									
										
										
										
											2024-03-18 16:55:26 +08:00
										 |  |  |         BOOLEAN = "boolean" | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         @classmethod | 
					
						
							|  |  |  |         def value_of(cls, value: str) -> "ToolProviderCredentials.CredentialsType": | 
					
						
							|  |  |  |             """
 | 
					
						
							|  |  |  |             Get value of given mode. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             :param value: mode value | 
					
						
							|  |  |  |             :return: mode | 
					
						
							|  |  |  |             """
 | 
					
						
							|  |  |  |             for mode in cls: | 
					
						
							|  |  |  |                 if mode.value == value: | 
					
						
							|  |  |  |                     return mode | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |             raise ValueError(f"invalid mode value {value}") | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         @staticmethod | 
					
						
							| 
									
										
										
										
											2024-01-31 11:58:07 +08:00
										 |  |  |         def default(value: str) -> str: | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |             return "" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     name: str = Field(..., description="The name of the credentials") | 
					
						
							|  |  |  |     type: CredentialsType = Field(..., description="The type of the credentials") | 
					
						
							|  |  |  |     required: bool = False | 
					
						
							| 
									
										
										
										
											2024-03-18 16:55:26 +08:00
										 |  |  |     default: Optional[Union[int, str]] = None | 
					
						
							| 
									
										
										
										
											2024-02-09 15:21:33 +08:00
										 |  |  |     options: Optional[list[ToolCredentialsOption]] = None | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |     label: Optional[I18nObject] = None | 
					
						
							|  |  |  |     help: Optional[I18nObject] = None | 
					
						
							|  |  |  |     url: Optional[str] = None | 
					
						
							|  |  |  |     placeholder: Optional[I18nObject] = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def to_dict(self) -> dict: | 
					
						
							|  |  |  |         return { | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |             "name": self.name, | 
					
						
							|  |  |  |             "type": self.type.value, | 
					
						
							|  |  |  |             "required": self.required, | 
					
						
							|  |  |  |             "default": self.default, | 
					
						
							|  |  |  |             "options": self.options, | 
					
						
							|  |  |  |             "help": self.help.to_dict() if self.help else None, | 
					
						
							|  |  |  |             "label": self.label.to_dict(), | 
					
						
							|  |  |  |             "url": self.url, | 
					
						
							|  |  |  |             "placeholder": self.placeholder.to_dict() if self.placeholder else None, | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolRuntimeVariableType(Enum): | 
					
						
							|  |  |  |     TEXT = "text" | 
					
						
							|  |  |  |     IMAGE = "image" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolRuntimeVariable(BaseModel): | 
					
						
							|  |  |  |     type: ToolRuntimeVariableType = Field(..., description="The type of the variable") | 
					
						
							|  |  |  |     name: str = Field(..., description="The name of the variable") | 
					
						
							|  |  |  |     position: int = Field(..., description="The position of the variable") | 
					
						
							|  |  |  |     tool_name: str = Field(..., description="The name of the tool") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolRuntimeTextVariable(ToolRuntimeVariable): | 
					
						
							|  |  |  |     value: str = Field(..., description="The value of the variable") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolRuntimeImageVariable(ToolRuntimeVariable): | 
					
						
							|  |  |  |     value: str = Field(..., description="The path of the image") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | class ToolRuntimeVariablePool(BaseModel): | 
					
						
							|  |  |  |     conversation_id: str = Field(..., description="The conversation id") | 
					
						
							|  |  |  |     user_id: str = Field(..., description="The user id") | 
					
						
							|  |  |  |     tenant_id: str = Field(..., description="The tenant id of assistant") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-09 15:21:33 +08:00
										 |  |  |     pool: list[ToolRuntimeVariable] = Field(..., description="The pool of variables") | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def __init__(self, **data: Any): | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         pool = data.get("pool", []) | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         # convert pool into correct type | 
					
						
							|  |  |  |         for index, variable in enumerate(pool): | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |             if variable["type"] == ToolRuntimeVariableType.TEXT.value: | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |                 pool[index] = ToolRuntimeTextVariable(**variable) | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |             elif variable["type"] == ToolRuntimeVariableType.IMAGE.value: | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |                 pool[index] = ToolRuntimeImageVariable(**variable) | 
					
						
							|  |  |  |         super().__init__(**data) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def dict(self) -> dict: | 
					
						
							|  |  |  |         return { | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |             "conversation_id": self.conversation_id, | 
					
						
							|  |  |  |             "user_id": self.user_id, | 
					
						
							|  |  |  |             "tenant_id": self.tenant_id, | 
					
						
							|  |  |  |             "pool": [variable.model_dump() for variable in self.pool], | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |     def set_text(self, tool_name: str, name: str, value: str) -> None: | 
					
						
							|  |  |  |         """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         set a text variable | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         """
 | 
					
						
							|  |  |  |         for variable in self.pool: | 
					
						
							|  |  |  |             if variable.name == name: | 
					
						
							|  |  |  |                 if variable.type == ToolRuntimeVariableType.TEXT: | 
					
						
							|  |  |  |                     variable = cast(ToolRuntimeTextVariable, variable) | 
					
						
							|  |  |  |                     variable.value = value | 
					
						
							|  |  |  |                     return | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         variable = ToolRuntimeTextVariable( | 
					
						
							|  |  |  |             type=ToolRuntimeVariableType.TEXT, | 
					
						
							|  |  |  |             name=name, | 
					
						
							|  |  |  |             position=len(self.pool), | 
					
						
							|  |  |  |             tool_name=tool_name, | 
					
						
							|  |  |  |             value=value, | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         self.pool.append(variable) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-09 14:36:43 +08:00
										 |  |  |     def set_file(self, tool_name: str, value: str, name: Optional[str] = None) -> None: | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         set an image variable | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |         :param tool_name: the name of the tool | 
					
						
							|  |  |  |         :param value: the id of the file | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         """
 | 
					
						
							|  |  |  |         # check how many image variables are there | 
					
						
							|  |  |  |         image_variable_count = 0 | 
					
						
							|  |  |  |         for variable in self.pool: | 
					
						
							|  |  |  |             if variable.type == ToolRuntimeVariableType.IMAGE: | 
					
						
							|  |  |  |                 image_variable_count += 1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if name is None: | 
					
						
							|  |  |  |             name = f"file_{image_variable_count}" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for variable in self.pool: | 
					
						
							|  |  |  |             if variable.name == name: | 
					
						
							|  |  |  |                 if variable.type == ToolRuntimeVariableType.IMAGE: | 
					
						
							|  |  |  |                     variable = cast(ToolRuntimeImageVariable, variable) | 
					
						
							|  |  |  |                     variable.value = value | 
					
						
							|  |  |  |                     return | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-23 19:58:23 +08:00
										 |  |  |         variable = ToolRuntimeImageVariable( | 
					
						
							|  |  |  |             type=ToolRuntimeVariableType.IMAGE, | 
					
						
							|  |  |  |             name=name, | 
					
						
							|  |  |  |             position=len(self.pool), | 
					
						
							|  |  |  |             tool_name=tool_name, | 
					
						
							|  |  |  |             value=value, | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 15:22:55 +08:00
										 |  |  |         self.pool.append(variable) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 15:22:55 +08:00
										 |  |  | class ModelToolPropertyKey(Enum): | 
					
						
							|  |  |  |     IMAGE_PARAMETER_NAME = "image_parameter_name" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 15:22:55 +08:00
										 |  |  | class ModelToolConfiguration(BaseModel): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Model tool configuration | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 15:22:55 +08:00
										 |  |  |     type: str = Field(..., description="The type of the model tool") | 
					
						
							|  |  |  |     model: str = Field(..., description="The model") | 
					
						
							|  |  |  |     label: I18nObject = Field(..., description="The label of the model tool") | 
					
						
							|  |  |  |     properties: dict[ModelToolPropertyKey, Any] = Field(..., description="The properties of the model tool") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 15:22:55 +08:00
										 |  |  | class ModelToolProviderConfiguration(BaseModel): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Model tool provider configuration | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 15:22:55 +08:00
										 |  |  |     provider: str = Field(..., description="The provider of the model tool") | 
					
						
							|  |  |  |     models: list[ModelToolConfiguration] = Field(..., description="The models of the model tool") | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     label: I18nObject = Field(..., description="The label of the model tool") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | class WorkflowToolParameterConfiguration(BaseModel): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Workflow tool configuration | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  |     name: str = Field(..., description="The name of the parameter") | 
					
						
							|  |  |  |     description: str = Field(..., description="The description of the parameter") | 
					
						
							|  |  |  |     form: ToolParameter.ToolParameterForm = Field(..., description="The form of the parameter") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | class ToolInvokeMeta(BaseModel): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Tool invoke meta | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     time_cost: float = Field(..., description="The time cost of the tool invoke") | 
					
						
							|  |  |  |     error: Optional[str] = None | 
					
						
							|  |  |  |     tool_config: Optional[dict] = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @classmethod | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     def empty(cls) -> "ToolInvokeMeta": | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         """
 | 
					
						
							|  |  |  |         Get an empty instance of ToolInvokeMeta | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         return cls(time_cost=0.0, error=None, tool_config={}) | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     @classmethod | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |     def error_instance(cls, error: str) -> "ToolInvokeMeta": | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         """
 | 
					
						
							|  |  |  |         Get an instance of ToolInvokeMeta with error | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         return cls(time_cost=0.0, error=error, tool_config={}) | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     def to_dict(self) -> dict: | 
					
						
							|  |  |  |         return { | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  |             "time_cost": self.time_cost, | 
					
						
							|  |  |  |             "error": self.error, | 
					
						
							|  |  |  |             "tool_config": self.tool_config, | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  | class ToolLabel(BaseModel): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Tool label | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  |     name: str = Field(..., description="The name of the tool") | 
					
						
							|  |  |  |     label: I18nObject = Field(..., description="The label of the tool") | 
					
						
							|  |  |  |     icon: str = Field(..., description="The icon of the tool") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  | class ToolInvokeFrom(Enum): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Enum class for tool invoke | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2024-09-10 17:00:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 22:01:11 +08:00
										 |  |  |     WORKFLOW = "workflow" | 
					
						
							| 
									
										
										
										
											2024-08-14 14:08:54 +08:00
										 |  |  |     AGENT = "agent" |