This commit is contained in:
jyong
2025-05-15 15:14:52 +08:00
parent 3f1363503b
commit 818eb46a8b
21 changed files with 2117 additions and 149 deletions

View File

@ -2,13 +2,13 @@ from collections.abc import Generator
from typing import Any, Optional
from core.datasource.__base.datasource_runtime import DatasourceRuntime
from core.datasource.datasource_manager import DatasourceManager
from core.datasource.entities.datasource_entities import (
DatasourceEntity,
DatasourceInvokeMessage,
DatasourceParameter,
DatasourceProviderType,
)
from core.plugin.manager.datasource import PluginDatasourceManager
from core.plugin.utils.converter import convert_parameters_to_plugin_format
@ -44,7 +44,7 @@ class DatasourcePlugin:
datasource_parameters: dict[str, Any],
rag_pipeline_id: Optional[str] = None,
) -> Generator[DatasourceInvokeMessage, None, None]:
manager = PluginDatasourceManager()
manager = DatasourceManager()
datasource_parameters = convert_parameters_to_plugin_format(datasource_parameters)
@ -64,7 +64,7 @@ class DatasourcePlugin:
datasource_parameters: dict[str, Any],
rag_pipeline_id: Optional[str] = None,
) -> Generator[DatasourceInvokeMessage, None, None]:
manager = PluginDatasourceManager()
manager = DatasourceManager()
datasource_parameters = convert_parameters_to_plugin_format(datasource_parameters)

View File

@ -4,12 +4,11 @@ from core.datasource.__base.datasource_plugin import DatasourcePlugin
from core.datasource.__base.datasource_runtime import DatasourceRuntime
from core.datasource.entities.datasource_entities import DatasourceProviderEntityWithPlugin, DatasourceProviderType
from core.entities.provider_entities import ProviderConfig
from core.plugin.manager.tool import PluginToolManager
from core.tools.builtin_tool.provider import BuiltinToolProviderController
from core.plugin.impl.tool import PluginToolManager
from core.tools.errors import ToolProviderCredentialValidationError
class DatasourcePluginProviderController(BuiltinToolProviderController):
class DatasourcePluginProviderController:
entity: DatasourceProviderEntityWithPlugin
tenant_id: str
plugin_id: str
@ -32,12 +31,21 @@ class DatasourcePluginProviderController(BuiltinToolProviderController):
"""
return DatasourceProviderType.RAG_PIPELINE
@property
def need_credentials(self) -> bool:
"""
returns whether the provider needs credentials
:return: whether the provider needs credentials
"""
return self.entity.credentials_schema is not None and len(self.entity.credentials_schema) != 0
def _validate_credentials(self, user_id: str, credentials: dict[str, Any]) -> None:
"""
validate the credentials of the provider
"""
manager = PluginToolManager()
if not manager.validate_provider_credentials(
if not manager.validate_datasource_credentials(
tenant_id=self.tenant_id,
user_id=user_id,
provider=self.entity.identity.name,
@ -69,7 +77,7 @@ class DatasourcePluginProviderController(BuiltinToolProviderController):
plugin_unique_identifier=self.plugin_unique_identifier,
)
def get_datasources(self) -> list[DatasourceTool]: # type: ignore
def get_datasources(self) -> list[DatasourcePlugin]: # type: ignore
"""
get all datasources
"""