2024-08-30 18:11:38 +08:00
|
|
|
from pydantic import Field
|
|
|
|
|
|
|
|
from core.entities.provider_entities import ProviderConfig
|
2024-09-20 02:25:14 +08:00
|
|
|
from core.tools.__base.tool_provider import ToolProviderController
|
|
|
|
from core.tools.custom_tool.tool import ApiTool
|
2024-01-23 19:58:23 +08:00
|
|
|
from core.tools.entities.common_entities import I18nObject
|
2024-05-27 22:01:11 +08:00
|
|
|
from core.tools.entities.tool_bundle import ApiToolBundle
|
2024-02-06 13:21:13 +08:00
|
|
|
from core.tools.entities.tool_entities import (
|
|
|
|
ApiProviderAuthType,
|
|
|
|
ToolProviderType,
|
|
|
|
)
|
2024-01-23 19:58:23 +08:00
|
|
|
from extensions.ext_database import db
|
|
|
|
from models.tools import ApiToolProvider
|
|
|
|
|
2024-02-01 18:11:57 +08:00
|
|
|
|
2024-05-27 22:01:11 +08:00
|
|
|
class ApiToolProviderController(ToolProviderController):
|
2024-04-08 18:51:46 +08:00
|
|
|
provider_id: str
|
2024-08-30 18:11:38 +08:00
|
|
|
tenant_id: str
|
|
|
|
tools: list[ApiTool] = Field(default_factory=list)
|
2024-04-08 18:51:46 +08:00
|
|
|
|
2024-01-23 19:58:23 +08:00
|
|
|
@staticmethod
|
2024-09-10 17:00:20 +08:00
|
|
|
def from_db(db_provider: ApiToolProvider, auth_type: ApiProviderAuthType) -> "ApiToolProviderController":
|
2024-01-23 19:58:23 +08:00
|
|
|
credentials_schema = {
|
2024-09-14 02:47:01 +08:00
|
|
|
"auth_type": ProviderConfig(
|
2024-09-10 17:00:20 +08:00
|
|
|
name="auth_type",
|
2024-01-23 19:58:23 +08:00
|
|
|
required=True,
|
2024-08-30 14:23:14 +08:00
|
|
|
type=ProviderConfig.Type.SELECT,
|
2024-01-23 19:58:23 +08:00
|
|
|
options=[
|
2024-09-14 02:47:01 +08:00
|
|
|
ProviderConfig.Option(value="none", label=I18nObject(en_US="None", zh_Hans="无")),
|
|
|
|
ProviderConfig.Option(value="api_key", label=I18nObject(en_US="api_key", zh_Hans="api_key")),
|
2024-01-23 19:58:23 +08:00
|
|
|
],
|
2024-09-10 17:00:20 +08:00
|
|
|
default="none",
|
|
|
|
help=I18nObject(en_US="The auth type of the api provider", zh_Hans="api provider 的认证类型"),
|
2024-01-23 19:58:23 +08:00
|
|
|
)
|
|
|
|
}
|
|
|
|
if auth_type == ApiProviderAuthType.API_KEY:
|
|
|
|
credentials_schema = {
|
|
|
|
**credentials_schema,
|
2024-09-14 02:47:01 +08:00
|
|
|
"api_key_header": ProviderConfig(
|
2024-09-10 17:00:20 +08:00
|
|
|
name="api_key_header",
|
2024-01-23 19:58:23 +08:00
|
|
|
required=False,
|
2024-09-10 17:00:20 +08:00
|
|
|
default="api_key",
|
2024-08-30 14:23:14 +08:00
|
|
|
type=ProviderConfig.Type.TEXT_INPUT,
|
2024-09-10 17:00:20 +08:00
|
|
|
help=I18nObject(en_US="The header name of the api key", zh_Hans="携带 api key 的 header 名称"),
|
2024-01-23 19:58:23 +08:00
|
|
|
),
|
2024-09-14 02:47:01 +08:00
|
|
|
"api_key_value": ProviderConfig(
|
2024-09-10 17:00:20 +08:00
|
|
|
name="api_key_value",
|
2024-01-23 19:58:23 +08:00
|
|
|
required=True,
|
2024-08-30 14:23:14 +08:00
|
|
|
type=ProviderConfig.Type.SECRET_INPUT,
|
2024-09-10 17:00:20 +08:00
|
|
|
help=I18nObject(en_US="The api key", zh_Hans="api key的值"),
|
2024-02-28 23:19:08 +08:00
|
|
|
),
|
2024-09-14 02:47:01 +08:00
|
|
|
"api_key_header_prefix": ProviderConfig(
|
2024-09-10 17:00:20 +08:00
|
|
|
name="api_key_header_prefix",
|
2024-02-28 23:19:08 +08:00
|
|
|
required=False,
|
2024-09-10 17:00:20 +08:00
|
|
|
default="basic",
|
2024-08-30 14:23:14 +08:00
|
|
|
type=ProviderConfig.Type.SELECT,
|
2024-09-10 17:00:20 +08:00
|
|
|
help=I18nObject(en_US="The prefix of the api key header", zh_Hans="api key header 的前缀"),
|
2024-02-28 23:19:08 +08:00
|
|
|
options=[
|
2024-09-14 02:47:01 +08:00
|
|
|
ProviderConfig.Option(value="basic", label=I18nObject(en_US="Basic", zh_Hans="Basic")),
|
|
|
|
ProviderConfig.Option(value="bearer", label=I18nObject(en_US="Bearer", zh_Hans="Bearer")),
|
|
|
|
ProviderConfig.Option(value="custom", label=I18nObject(en_US="Custom", zh_Hans="Custom")),
|
2024-09-10 17:00:20 +08:00
|
|
|
],
|
|
|
|
),
|
2024-01-23 19:58:23 +08:00
|
|
|
}
|
|
|
|
elif auth_type == ApiProviderAuthType.NONE:
|
|
|
|
pass
|
|
|
|
else:
|
2024-09-10 17:00:20 +08:00
|
|
|
raise ValueError(f"invalid auth type {auth_type}")
|
|
|
|
|
2024-09-20 02:25:14 +08:00
|
|
|
user = db_provider.user
|
|
|
|
user_name = user.name if user else ""
|
2024-09-10 17:00:20 +08:00
|
|
|
|
|
|
|
return ApiToolProviderController(
|
|
|
|
**{
|
|
|
|
"identity": {
|
|
|
|
"author": user_name,
|
|
|
|
"name": db_provider.name,
|
|
|
|
"label": {"en_US": db_provider.name, "zh_Hans": db_provider.name},
|
|
|
|
"description": {"en_US": db_provider.description, "zh_Hans": db_provider.description},
|
|
|
|
"icon": db_provider.icon,
|
2024-01-23 19:58:23 +08:00
|
|
|
},
|
2024-09-10 17:00:20 +08:00
|
|
|
"credentials_schema": credentials_schema,
|
|
|
|
"provider_id": db_provider.id or "",
|
2024-09-14 02:47:01 +08:00
|
|
|
"tenant_id": db_provider.tenant_id or "",
|
2024-01-23 19:58:23 +08:00
|
|
|
},
|
2024-09-10 17:00:20 +08:00
|
|
|
)
|
2024-01-23 19:58:23 +08:00
|
|
|
|
|
|
|
@property
|
2024-05-27 22:01:11 +08:00
|
|
|
def provider_type(self) -> ToolProviderType:
|
|
|
|
return ToolProviderType.API
|
2024-01-23 19:58:23 +08:00
|
|
|
|
2024-05-27 22:01:11 +08:00
|
|
|
def _parse_tool_bundle(self, tool_bundle: ApiToolBundle) -> ApiTool:
|
2024-01-23 19:58:23 +08:00
|
|
|
"""
|
2024-09-10 17:00:20 +08:00
|
|
|
parse tool bundle to tool
|
2024-01-23 19:58:23 +08:00
|
|
|
|
2024-09-10 17:00:20 +08:00
|
|
|
:param tool_bundle: the tool bundle
|
|
|
|
:return: the tool
|
2024-01-23 19:58:23 +08:00
|
|
|
"""
|
2024-09-10 17:00:20 +08:00
|
|
|
return ApiTool(
|
|
|
|
**{
|
|
|
|
"api_bundle": tool_bundle,
|
|
|
|
"identity": {
|
|
|
|
"author": tool_bundle.author,
|
|
|
|
"name": tool_bundle.operation_id,
|
|
|
|
"label": {"en_US": tool_bundle.operation_id, "zh_Hans": tool_bundle.operation_id},
|
|
|
|
"icon": self.identity.icon,
|
|
|
|
"provider": self.provider_id,
|
2024-01-23 19:58:23 +08:00
|
|
|
},
|
2024-09-10 17:00:20 +08:00
|
|
|
"description": {
|
|
|
|
"human": {"en_US": tool_bundle.summary or "", "zh_Hans": tool_bundle.summary or ""},
|
|
|
|
"llm": tool_bundle.summary or "",
|
2024-01-23 19:58:23 +08:00
|
|
|
},
|
2024-09-12 15:50:49 +08:00
|
|
|
"parameters": tool_bundle.parameters or [],
|
2024-09-10 17:00:20 +08:00
|
|
|
}
|
|
|
|
)
|
2024-01-23 19:58:23 +08:00
|
|
|
|
2024-05-27 22:01:11 +08:00
|
|
|
def load_bundled_tools(self, tools: list[ApiToolBundle]) -> list[ApiTool]:
|
2024-01-23 19:58:23 +08:00
|
|
|
"""
|
2024-09-10 17:00:20 +08:00
|
|
|
load bundled tools
|
2024-01-23 19:58:23 +08:00
|
|
|
|
2024-09-10 17:00:20 +08:00
|
|
|
:param tools: the bundled tools
|
|
|
|
:return: the tools
|
2024-01-23 19:58:23 +08:00
|
|
|
"""
|
|
|
|
self.tools = [self._parse_tool_bundle(tool) for tool in tools]
|
|
|
|
|
|
|
|
return self.tools
|
|
|
|
|
2024-08-30 18:11:38 +08:00
|
|
|
def get_tools(self, tenant_id: str) -> list[ApiTool]:
|
2024-01-23 19:58:23 +08:00
|
|
|
"""
|
2024-09-10 17:00:20 +08:00
|
|
|
fetch tools from database
|
2024-01-23 19:58:23 +08:00
|
|
|
|
2024-09-10 17:00:20 +08:00
|
|
|
:param user_id: the user id
|
|
|
|
:param tenant_id: the tenant id
|
|
|
|
:return: the tools
|
2024-01-23 19:58:23 +08:00
|
|
|
"""
|
|
|
|
if self.tools is not None:
|
|
|
|
return self.tools
|
2024-09-10 17:00:20 +08:00
|
|
|
|
2024-08-30 18:11:38 +08:00
|
|
|
tools: list[ApiTool] = []
|
2024-01-23 19:58:23 +08:00
|
|
|
|
2024-01-31 11:58:07 +08:00
|
|
|
# get tenant api providers
|
2024-09-10 17:00:20 +08:00
|
|
|
db_providers: list[ApiToolProvider] = (
|
|
|
|
db.session.query(ApiToolProvider)
|
|
|
|
.filter(ApiToolProvider.tenant_id == tenant_id, ApiToolProvider.name == self.identity.name)
|
|
|
|
.all()
|
|
|
|
)
|
2024-01-23 19:58:23 +08:00
|
|
|
|
|
|
|
if db_providers and len(db_providers) != 0:
|
|
|
|
for db_provider in db_providers:
|
|
|
|
for tool in db_provider.tools:
|
|
|
|
assistant_tool = self._parse_tool_bundle(tool)
|
|
|
|
assistant_tool.is_team_authorization = True
|
|
|
|
tools.append(assistant_tool)
|
2024-09-10 17:00:20 +08:00
|
|
|
|
2024-01-23 19:58:23 +08:00
|
|
|
self.tools = tools
|
|
|
|
return tools
|
2024-09-10 17:00:20 +08:00
|
|
|
|
2024-01-23 19:58:23 +08:00
|
|
|
def get_tool(self, tool_name: str) -> ApiTool:
|
|
|
|
"""
|
2024-09-10 17:00:20 +08:00
|
|
|
get tool by name
|
2024-01-23 19:58:23 +08:00
|
|
|
|
2024-09-10 17:00:20 +08:00
|
|
|
:param tool_name: the name of the tool
|
|
|
|
:return: the tool
|
2024-01-23 19:58:23 +08:00
|
|
|
"""
|
|
|
|
if self.tools is None:
|
2024-08-30 18:11:38 +08:00
|
|
|
self.get_tools(self.tenant_id)
|
2024-01-23 19:58:23 +08:00
|
|
|
|
|
|
|
for tool in self.tools:
|
|
|
|
if tool.identity.name == tool_name:
|
|
|
|
return tool
|
|
|
|
|
2024-09-10 17:00:20 +08:00
|
|
|
raise ValueError(f"tool {tool_name} not found")
|