mirror of
				https://github.com/langgenius/dify.git
				synced 2025-11-04 12:53:38 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			264 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			264 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from collections.abc import Sequence
 | 
						|
 | 
						|
from core.plugin.entities.bundle import PluginBundleDependency
 | 
						|
from core.plugin.entities.plugin import (
 | 
						|
    GenericProviderID,
 | 
						|
    MissingPluginDependency,
 | 
						|
    PluginDeclaration,
 | 
						|
    PluginEntity,
 | 
						|
    PluginInstallation,
 | 
						|
    PluginInstallationSource,
 | 
						|
)
 | 
						|
from core.plugin.entities.plugin_daemon import (
 | 
						|
    PluginInstallTask,
 | 
						|
    PluginInstallTaskStartResponse,
 | 
						|
    PluginListResponse,
 | 
						|
    PluginUploadResponse,
 | 
						|
)
 | 
						|
from core.plugin.impl.base import BasePluginClient
 | 
						|
 | 
						|
 | 
						|
class PluginInstaller(BasePluginClient):
 | 
						|
    def fetch_plugin_by_identifier(
 | 
						|
        self,
 | 
						|
        tenant_id: str,
 | 
						|
        identifier: str,
 | 
						|
    ) -> bool:
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "GET",
 | 
						|
            f"plugin/{tenant_id}/management/fetch/identifier",
 | 
						|
            bool,
 | 
						|
            params={"plugin_unique_identifier": identifier},
 | 
						|
        )
 | 
						|
 | 
						|
    def list_plugins(self, tenant_id: str) -> list[PluginEntity]:
 | 
						|
        result = self._request_with_plugin_daemon_response(
 | 
						|
            "GET",
 | 
						|
            f"plugin/{tenant_id}/management/list",
 | 
						|
            PluginListResponse,
 | 
						|
            params={"page": 1, "page_size": 256},
 | 
						|
        )
 | 
						|
        return result.list
 | 
						|
 | 
						|
    def list_plugins_with_total(self, tenant_id: str, page: int, page_size: int) -> PluginListResponse:
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "GET",
 | 
						|
            f"plugin/{tenant_id}/management/list",
 | 
						|
            PluginListResponse,
 | 
						|
            params={"page": page, "page_size": page_size},
 | 
						|
        )
 | 
						|
 | 
						|
    def upload_pkg(
 | 
						|
        self,
 | 
						|
        tenant_id: str,
 | 
						|
        pkg: bytes,
 | 
						|
        verify_signature: bool = False,
 | 
						|
    ) -> PluginUploadResponse:
 | 
						|
        """
 | 
						|
        Upload a plugin package and return the plugin unique identifier.
 | 
						|
        """
 | 
						|
        body = {
 | 
						|
            "dify_pkg": ("dify_pkg", pkg, "application/octet-stream"),
 | 
						|
        }
 | 
						|
 | 
						|
        data = {
 | 
						|
            "verify_signature": "true" if verify_signature else "false",
 | 
						|
        }
 | 
						|
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/install/upload/package",
 | 
						|
            PluginUploadResponse,
 | 
						|
            files=body,
 | 
						|
            data=data,
 | 
						|
        )
 | 
						|
 | 
						|
    def upload_bundle(
 | 
						|
        self,
 | 
						|
        tenant_id: str,
 | 
						|
        bundle: bytes,
 | 
						|
        verify_signature: bool = False,
 | 
						|
    ) -> Sequence[PluginBundleDependency]:
 | 
						|
        """
 | 
						|
        Upload a plugin bundle and return the dependencies.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/install/upload/bundle",
 | 
						|
            list[PluginBundleDependency],
 | 
						|
            files={"dify_bundle": ("dify_bundle", bundle, "application/octet-stream")},
 | 
						|
            data={"verify_signature": "true" if verify_signature else "false"},
 | 
						|
        )
 | 
						|
 | 
						|
    def install_from_identifiers(
 | 
						|
        self,
 | 
						|
        tenant_id: str,
 | 
						|
        identifiers: Sequence[str],
 | 
						|
        source: PluginInstallationSource,
 | 
						|
        metas: list[dict],
 | 
						|
    ) -> PluginInstallTaskStartResponse:
 | 
						|
        """
 | 
						|
        Install a plugin from an identifier.
 | 
						|
        """
 | 
						|
        # exception will be raised if the request failed
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/install/identifiers",
 | 
						|
            PluginInstallTaskStartResponse,
 | 
						|
            data={
 | 
						|
                "plugin_unique_identifiers": identifiers,
 | 
						|
                "source": source,
 | 
						|
                "metas": metas,
 | 
						|
            },
 | 
						|
            headers={"Content-Type": "application/json"},
 | 
						|
        )
 | 
						|
 | 
						|
    def fetch_plugin_installation_tasks(self, tenant_id: str, page: int, page_size: int) -> Sequence[PluginInstallTask]:
 | 
						|
        """
 | 
						|
        Fetch plugin installation tasks.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "GET",
 | 
						|
            f"plugin/{tenant_id}/management/install/tasks",
 | 
						|
            list[PluginInstallTask],
 | 
						|
            params={"page": page, "page_size": page_size},
 | 
						|
        )
 | 
						|
 | 
						|
    def fetch_plugin_installation_task(self, tenant_id: str, task_id: str) -> PluginInstallTask:
 | 
						|
        """
 | 
						|
        Fetch a plugin installation task.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "GET",
 | 
						|
            f"plugin/{tenant_id}/management/install/tasks/{task_id}",
 | 
						|
            PluginInstallTask,
 | 
						|
        )
 | 
						|
 | 
						|
    def delete_plugin_installation_task(self, tenant_id: str, task_id: str) -> bool:
 | 
						|
        """
 | 
						|
        Delete a plugin installation task.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/install/tasks/{task_id}/delete",
 | 
						|
            bool,
 | 
						|
        )
 | 
						|
 | 
						|
    def delete_all_plugin_installation_task_items(self, tenant_id: str) -> bool:
 | 
						|
        """
 | 
						|
        Delete all plugin installation task items.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/install/tasks/delete_all",
 | 
						|
            bool,
 | 
						|
        )
 | 
						|
 | 
						|
    def delete_plugin_installation_task_item(self, tenant_id: str, task_id: str, identifier: str) -> bool:
 | 
						|
        """
 | 
						|
        Delete a plugin installation task item.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/install/tasks/{task_id}/delete/{identifier}",
 | 
						|
            bool,
 | 
						|
        )
 | 
						|
 | 
						|
    def fetch_plugin_manifest(self, tenant_id: str, plugin_unique_identifier: str) -> PluginDeclaration:
 | 
						|
        """
 | 
						|
        Fetch a plugin manifest.
 | 
						|
        """
 | 
						|
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "GET",
 | 
						|
            f"plugin/{tenant_id}/management/fetch/manifest",
 | 
						|
            PluginDeclaration,
 | 
						|
            params={"plugin_unique_identifier": plugin_unique_identifier},
 | 
						|
        )
 | 
						|
 | 
						|
    def fetch_plugin_installation_by_ids(
 | 
						|
        self, tenant_id: str, plugin_ids: Sequence[str]
 | 
						|
    ) -> Sequence[PluginInstallation]:
 | 
						|
        """
 | 
						|
        Fetch plugin installations by ids.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/installation/fetch/batch",
 | 
						|
            list[PluginInstallation],
 | 
						|
            data={"plugin_ids": plugin_ids},
 | 
						|
            headers={"Content-Type": "application/json"},
 | 
						|
        )
 | 
						|
 | 
						|
    def fetch_missing_dependencies(
 | 
						|
        self, tenant_id: str, plugin_unique_identifiers: list[str]
 | 
						|
    ) -> list[MissingPluginDependency]:
 | 
						|
        """
 | 
						|
        Fetch missing dependencies
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/installation/missing",
 | 
						|
            list[MissingPluginDependency],
 | 
						|
            data={"plugin_unique_identifiers": plugin_unique_identifiers},
 | 
						|
            headers={"Content-Type": "application/json"},
 | 
						|
        )
 | 
						|
 | 
						|
    def uninstall(self, tenant_id: str, plugin_installation_id: str) -> bool:
 | 
						|
        """
 | 
						|
        Uninstall a plugin.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/uninstall",
 | 
						|
            bool,
 | 
						|
            data={
 | 
						|
                "plugin_installation_id": plugin_installation_id,
 | 
						|
            },
 | 
						|
            headers={"Content-Type": "application/json"},
 | 
						|
        )
 | 
						|
 | 
						|
    def upgrade_plugin(
 | 
						|
        self,
 | 
						|
        tenant_id: str,
 | 
						|
        original_plugin_unique_identifier: str,
 | 
						|
        new_plugin_unique_identifier: str,
 | 
						|
        source: PluginInstallationSource,
 | 
						|
        meta: dict,
 | 
						|
    ) -> PluginInstallTaskStartResponse:
 | 
						|
        """
 | 
						|
        Upgrade a plugin.
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/install/upgrade",
 | 
						|
            PluginInstallTaskStartResponse,
 | 
						|
            data={
 | 
						|
                "original_plugin_unique_identifier": original_plugin_unique_identifier,
 | 
						|
                "new_plugin_unique_identifier": new_plugin_unique_identifier,
 | 
						|
                "source": source,
 | 
						|
                "meta": meta,
 | 
						|
            },
 | 
						|
            headers={"Content-Type": "application/json"},
 | 
						|
        )
 | 
						|
 | 
						|
    def check_tools_existence(self, tenant_id: str, provider_ids: Sequence[GenericProviderID]) -> Sequence[bool]:
 | 
						|
        """
 | 
						|
        Check if the tools exist
 | 
						|
        """
 | 
						|
        return self._request_with_plugin_daemon_response(
 | 
						|
            "POST",
 | 
						|
            f"plugin/{tenant_id}/management/tools/check_existence",
 | 
						|
            list[bool],
 | 
						|
            data={
 | 
						|
                "provider_ids": [
 | 
						|
                    {
 | 
						|
                        "plugin_id": provider_id.plugin_id,
 | 
						|
                        "provider_name": provider_id.provider_name,
 | 
						|
                    }
 | 
						|
                    for provider_id in provider_ids
 | 
						|
                ]
 | 
						|
            },
 | 
						|
            headers={"Content-Type": "application/json"},
 | 
						|
        )
 |