|
@@ -8,9 +8,12 @@ from werkzeug.exceptions import Forbidden
|
|
|
from configs import dify_config
|
|
|
from controllers.console import api
|
|
|
from controllers.console.setup import setup_required
|
|
|
+from controllers.console.workspace import plugin_permission_required
|
|
|
from controllers.console.wraps import account_initialization_required
|
|
|
from core.model_runtime.utils.encoders import jsonable_encoder
|
|
|
from libs.login import login_required
|
|
|
+from models.account import TenantPluginPermission
|
|
|
+from services.plugin.plugin_permission_service import PluginPermissionService
|
|
|
from services.plugin.plugin_service import PluginService
|
|
|
|
|
|
|
|
@@ -18,12 +21,9 @@ class PluginDebuggingKeyApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def get(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
return {
|
|
|
"key": PluginService.get_debugging_key(tenant_id),
|
|
@@ -37,8 +37,7 @@ class PluginListApi(Resource):
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
def get(self):
|
|
|
- user = current_user
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
plugins = PluginService.list(tenant_id)
|
|
|
return jsonable_encoder({"plugins": plugins})
|
|
|
|
|
@@ -57,32 +56,13 @@ class PluginIconApi(Resource):
|
|
|
return send_file(io.BytesIO(icon_bytes), mimetype=mimetype, max_age=icon_cache_max_age)
|
|
|
|
|
|
|
|
|
-class PluginUploadPkgApi(Resource):
|
|
|
- @setup_required
|
|
|
- @login_required
|
|
|
- @account_initialization_required
|
|
|
- def post(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
- file = request.files["pkg"]
|
|
|
- content = file.read()
|
|
|
-
|
|
|
- return jsonable_encoder(PluginService.upload_pkg(tenant_id, content))
|
|
|
-
|
|
|
-
|
|
|
class PluginUploadFromPkgApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(install_required=True)
|
|
|
def post(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
file = request.files["pkg"]
|
|
|
|
|
@@ -100,12 +80,9 @@ class PluginUploadFromGithubApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(install_required=True)
|
|
|
def post(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
parser.add_argument("repo", type=str, required=True, location="json")
|
|
@@ -124,12 +101,9 @@ class PluginInstallFromPkgApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(install_required=True)
|
|
|
def post(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
parser.add_argument("plugin_unique_identifiers", type=list, required=True, location="json")
|
|
@@ -149,12 +123,9 @@ class PluginInstallFromGithubApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(install_required=True)
|
|
|
def post(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
parser.add_argument("repo", type=str, required=True, location="json")
|
|
@@ -178,12 +149,9 @@ class PluginInstallFromMarketplaceApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(install_required=True)
|
|
|
def post(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
parser.add_argument("plugin_unique_identifiers", type=list, required=True, location="json")
|
|
@@ -203,15 +171,14 @@ class PluginFetchManifestApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def get(self):
|
|
|
- user = current_user
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
parser.add_argument("plugin_unique_identifier", type=str, required=True, location="args")
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
-
|
|
|
return jsonable_encoder(
|
|
|
{"manifest": PluginService.fetch_plugin_manifest(tenant_id, args["plugin_unique_identifier"]).model_dump()}
|
|
|
)
|
|
@@ -221,12 +188,9 @@ class PluginFetchInstallTasksApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def get(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
parser.add_argument("page", type=int, required=True, location="args")
|
|
@@ -242,12 +206,9 @@ class PluginFetchInstallTaskApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def get(self, task_id: str):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
return jsonable_encoder({"task": PluginService.fetch_install_task(tenant_id, task_id)})
|
|
|
|
|
@@ -256,12 +217,9 @@ class PluginDeleteInstallTaskApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def post(self, task_id: str):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
return {"success": PluginService.delete_install_task(tenant_id, task_id)}
|
|
|
|
|
@@ -270,12 +228,9 @@ class PluginDeleteInstallTaskItemApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def post(self, task_id: str, identifier: str):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
return {"success": PluginService.delete_install_task_item(tenant_id, task_id, identifier)}
|
|
|
|
|
@@ -284,12 +239,9 @@ class PluginUpgradeFromMarketplaceApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def post(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
parser.add_argument("original_plugin_unique_identifier", type=str, required=True, location="json")
|
|
@@ -307,12 +259,9 @@ class PluginUpgradeFromGithubApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def post(self):
|
|
|
- user = current_user
|
|
|
- if not user.is_admin_or_owner:
|
|
|
- raise Forbidden()
|
|
|
-
|
|
|
- tenant_id = user.current_tenant_id
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
parser.add_argument("original_plugin_unique_identifier", type=str, required=True, location="json")
|
|
@@ -338,18 +287,62 @@ class PluginUninstallApi(Resource):
|
|
|
@setup_required
|
|
|
@login_required
|
|
|
@account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
def post(self):
|
|
|
req = reqparse.RequestParser()
|
|
|
req.add_argument("plugin_installation_id", type=str, required=True, location="json")
|
|
|
args = req.parse_args()
|
|
|
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
+
|
|
|
+ return {"success": PluginService.uninstall(tenant_id, args["plugin_installation_id"])}
|
|
|
+
|
|
|
+
|
|
|
+class PluginChangePermissionApi(Resource):
|
|
|
+ @setup_required
|
|
|
+ @login_required
|
|
|
+ @account_initialization_required
|
|
|
+ @plugin_permission_required(debug_required=True)
|
|
|
+ def post(self):
|
|
|
user = current_user
|
|
|
if not user.is_admin_or_owner:
|
|
|
raise Forbidden()
|
|
|
|
|
|
+ req = reqparse.RequestParser()
|
|
|
+ req.add_argument("install_permission", type=str, required=True, location="json")
|
|
|
+ req.add_argument("debug_permission", type=str, required=True, location="json")
|
|
|
+ args = req.parse_args()
|
|
|
+
|
|
|
+ install_permission = TenantPluginPermission.InstallPermission(args["install_permission"])
|
|
|
+ debug_permission = TenantPluginPermission.DebugPermission(args["debug_permission"])
|
|
|
+
|
|
|
tenant_id = user.current_tenant_id
|
|
|
|
|
|
- return {"success": PluginService.uninstall(tenant_id, args["plugin_installation_id"])}
|
|
|
+ return {"success": PluginPermissionService.change_permission(tenant_id, install_permission, debug_permission)}
|
|
|
+
|
|
|
+
|
|
|
+class PluginFetchPermissionApi(Resource):
|
|
|
+ @setup_required
|
|
|
+ @login_required
|
|
|
+ @account_initialization_required
|
|
|
+ def get(self):
|
|
|
+ tenant_id = current_user.current_tenant_id
|
|
|
+
|
|
|
+ permission = PluginPermissionService.get_permission(tenant_id)
|
|
|
+ if not permission:
|
|
|
+ return jsonable_encoder(
|
|
|
+ {
|
|
|
+ "install_permission": TenantPluginPermission.InstallPermission.EVERYONE,
|
|
|
+ "debug_permission": TenantPluginPermission.DebugPermission.EVERYONE,
|
|
|
+ }
|
|
|
+ )
|
|
|
+
|
|
|
+ return jsonable_encoder(
|
|
|
+ {
|
|
|
+ "install_permission": permission.install_permission,
|
|
|
+ "debug_permission": permission.debug_permission,
|
|
|
+ }
|
|
|
+ )
|
|
|
|
|
|
|
|
|
api.add_resource(PluginDebuggingKeyApi, "/workspaces/current/plugin/debugging-key")
|
|
@@ -368,3 +361,6 @@ api.add_resource(PluginFetchInstallTaskApi, "/workspaces/current/plugin/tasks/<t
|
|
|
api.add_resource(PluginDeleteInstallTaskApi, "/workspaces/current/plugin/tasks/<task_id>/delete")
|
|
|
api.add_resource(PluginDeleteInstallTaskItemApi, "/workspaces/current/plugin/tasks/<task_id>/delete/<path:identifier>")
|
|
|
api.add_resource(PluginUninstallApi, "/workspaces/current/plugin/uninstall")
|
|
|
+
|
|
|
+api.add_resource(PluginChangePermissionApi, "/workspaces/current/plugin/permission/change")
|
|
|
+api.add_resource(PluginFetchPermissionApi, "/workspaces/current/plugin/permission/fetch")
|