| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365 | import iofrom flask import current_app, send_filefrom flask_login import current_userfrom flask_restful import Resource, reqparsefrom werkzeug.exceptions import Forbiddenfrom controllers.console import apifrom controllers.console.setup import setup_requiredfrom controllers.console.wraps import account_initialization_requiredfrom core.model_runtime.utils.encoders import jsonable_encoderfrom libs.login import login_requiredfrom services.tools_manage_service import ToolManageServiceclass ToolProviderListApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self):        user_id = current_user.id        tenant_id = current_user.current_tenant_id        return ToolManageService.list_tool_providers(user_id, tenant_id)class ToolBuiltinProviderListToolsApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self, provider):        user_id = current_user.id        tenant_id = current_user.current_tenant_id        return jsonable_encoder(ToolManageService.list_builtin_tool_provider_tools(            user_id,            tenant_id,            provider,        ))class ToolBuiltinProviderDeleteApi(Resource):    @setup_required    @login_required    @account_initialization_required    def post(self, provider):        if not current_user.is_admin_or_owner:            raise Forbidden()                user_id = current_user.id        tenant_id = current_user.current_tenant_id        return ToolManageService.delete_builtin_tool_provider(            user_id,            tenant_id,            provider,        )    class ToolBuiltinProviderUpdateApi(Resource):    @setup_required    @login_required    @account_initialization_required    def post(self, provider):        if not current_user.is_admin_or_owner:            raise Forbidden()                user_id = current_user.id        tenant_id = current_user.current_tenant_id        parser = reqparse.RequestParser()        parser.add_argument('credentials', type=dict, required=True, nullable=False, location='json')        args = parser.parse_args()        return ToolManageService.update_builtin_tool_provider(            user_id,            tenant_id,            provider,            args['credentials'],        )    class ToolBuiltinProviderGetCredentialsApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self, provider):        user_id = current_user.id        tenant_id = current_user.current_tenant_id        return ToolManageService.get_builtin_tool_provider_credentials(            user_id,            tenant_id,            provider,        )class ToolBuiltinProviderIconApi(Resource):    @setup_required    def get(self, provider):        icon_bytes, mimetype = ToolManageService.get_builtin_tool_provider_icon(provider)        icon_cache_max_age = int(current_app.config.get('TOOL_ICON_CACHE_MAX_AGE'))        return send_file(io.BytesIO(icon_bytes), mimetype=mimetype, max_age=icon_cache_max_age)class ToolModelProviderIconApi(Resource):    @setup_required    def get(self, provider):        icon_bytes, mimetype = ToolManageService.get_model_tool_provider_icon(provider)        return send_file(io.BytesIO(icon_bytes), mimetype=mimetype)    class ToolModelProviderListToolsApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self):        user_id = current_user.id        tenant_id = current_user.current_tenant_id        parser = reqparse.RequestParser()        parser.add_argument('provider', type=str, required=True, nullable=False, location='args')        args = parser.parse_args()        return jsonable_encoder(ToolManageService.list_model_tool_provider_tools(            user_id,            tenant_id,            args['provider'],        ))class ToolApiProviderAddApi(Resource):    @setup_required    @login_required    @account_initialization_required    def post(self):        if not current_user.is_admin_or_owner:            raise Forbidden()                user_id = current_user.id        tenant_id = current_user.current_tenant_id        parser = reqparse.RequestParser()        parser.add_argument('credentials', type=dict, required=True, nullable=False, location='json')        parser.add_argument('schema_type', type=str, required=True, nullable=False, location='json')        parser.add_argument('schema', type=str, required=True, nullable=False, location='json')        parser.add_argument('provider', type=str, required=True, nullable=False, location='json')        parser.add_argument('icon', type=dict, required=True, nullable=False, location='json')        parser.add_argument('privacy_policy', type=str, required=False, nullable=True, location='json')        args = parser.parse_args()        return ToolManageService.create_api_tool_provider(            user_id,            tenant_id,            args['provider'],            args['icon'],            args['credentials'],            args['schema_type'],            args['schema'],            args.get('privacy_policy', ''),        )class ToolApiProviderGetRemoteSchemaApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self):        parser = reqparse.RequestParser()        parser.add_argument('url', type=str, required=True, nullable=False, location='args')        args = parser.parse_args()        return ToolManageService.get_api_tool_provider_remote_schema(            current_user.id,            current_user.current_tenant_id,            args['url'],        )    class ToolApiProviderListToolsApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self):        user_id = current_user.id        tenant_id = current_user.current_tenant_id        parser = reqparse.RequestParser()        parser.add_argument('provider', type=str, required=True, nullable=False, location='args')        args = parser.parse_args()        return jsonable_encoder(ToolManageService.list_api_tool_provider_tools(            user_id,            tenant_id,            args['provider'],        ))class ToolApiProviderUpdateApi(Resource):    @setup_required    @login_required    @account_initialization_required    def post(self):        if not current_user.is_admin_or_owner:            raise Forbidden()                user_id = current_user.id        tenant_id = current_user.current_tenant_id        parser = reqparse.RequestParser()        parser.add_argument('credentials', type=dict, required=True, nullable=False, location='json')        parser.add_argument('schema_type', type=str, required=True, nullable=False, location='json')        parser.add_argument('schema', type=str, required=True, nullable=False, location='json')        parser.add_argument('provider', type=str, required=True, nullable=False, location='json')        parser.add_argument('original_provider', type=str, required=True, nullable=False, location='json')        parser.add_argument('icon', type=dict, required=True, nullable=False, location='json')        parser.add_argument('privacy_policy', type=str, required=True, nullable=True, location='json')        args = parser.parse_args()        return ToolManageService.update_api_tool_provider(            user_id,            tenant_id,            args['provider'],            args['original_provider'],            args['icon'],            args['credentials'],            args['schema_type'],            args['schema'],            args['privacy_policy'],        )class ToolApiProviderDeleteApi(Resource):    @setup_required    @login_required    @account_initialization_required    def post(self):        if not current_user.is_admin_or_owner:            raise Forbidden()                user_id = current_user.id        tenant_id = current_user.current_tenant_id        parser = reqparse.RequestParser()        parser.add_argument('provider', type=str, required=True, nullable=False, location='json')        args = parser.parse_args()        return ToolManageService.delete_api_tool_provider(            user_id,            tenant_id,            args['provider'],        )class ToolApiProviderGetApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self):        user_id = current_user.id        tenant_id = current_user.current_tenant_id        parser = reqparse.RequestParser()        parser.add_argument('provider', type=str, required=True, nullable=False, location='args')        args = parser.parse_args()        return ToolManageService.get_api_tool_provider(            user_id,            tenant_id,            args['provider'],        )class ToolBuiltinProviderCredentialsSchemaApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self, provider):        return ToolManageService.list_builtin_provider_credentials_schema(provider)class ToolApiProviderSchemaApi(Resource):    @setup_required    @login_required    @account_initialization_required    def post(self):        parser = reqparse.RequestParser()        parser.add_argument('schema', type=str, required=True, nullable=False, location='json')        args = parser.parse_args()        return ToolManageService.parser_api_schema(            schema=args['schema'],        )class ToolApiProviderPreviousTestApi(Resource):    @setup_required    @login_required    @account_initialization_required    def post(self):        parser = reqparse.RequestParser()        parser.add_argument('tool_name', type=str, required=True, nullable=False, location='json')        parser.add_argument('provider_name', type=str, required=False, nullable=False, location='json')        parser.add_argument('credentials', type=dict, required=True, nullable=False, location='json')        parser.add_argument('parameters', type=dict, required=True, nullable=False, location='json')        parser.add_argument('schema_type', type=str, required=True, nullable=False, location='json')        parser.add_argument('schema', type=str, required=True, nullable=False, location='json')        args = parser.parse_args()        return ToolManageService.test_api_tool_preview(            current_user.current_tenant_id,            args['provider_name'] if args['provider_name'] else '',            args['tool_name'],            args['credentials'],            args['parameters'],            args['schema_type'],            args['schema'],        )class ToolBuiltinListApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self):        user_id = current_user.id        tenant_id = current_user.current_tenant_id        return jsonable_encoder([provider.to_dict() for provider in ToolManageService.list_builtin_tools(            user_id,            tenant_id,        )])    class ToolApiListApi(Resource):    @setup_required    @login_required    @account_initialization_required    def get(self):        user_id = current_user.id        tenant_id = current_user.current_tenant_id        return jsonable_encoder([provider.to_dict() for provider in ToolManageService.list_api_tools(            user_id,            tenant_id,        )])api.add_resource(ToolProviderListApi, '/workspaces/current/tool-providers')api.add_resource(ToolBuiltinProviderListToolsApi, '/workspaces/current/tool-provider/builtin/<provider>/tools')api.add_resource(ToolBuiltinProviderDeleteApi, '/workspaces/current/tool-provider/builtin/<provider>/delete')api.add_resource(ToolBuiltinProviderUpdateApi, '/workspaces/current/tool-provider/builtin/<provider>/update')api.add_resource(ToolBuiltinProviderGetCredentialsApi, '/workspaces/current/tool-provider/builtin/<provider>/credentials')api.add_resource(ToolBuiltinProviderCredentialsSchemaApi, '/workspaces/current/tool-provider/builtin/<provider>/credentials_schema')api.add_resource(ToolBuiltinProviderIconApi, '/workspaces/current/tool-provider/builtin/<provider>/icon')api.add_resource(ToolModelProviderIconApi, '/workspaces/current/tool-provider/model/<provider>/icon')api.add_resource(ToolModelProviderListToolsApi, '/workspaces/current/tool-provider/model/tools')api.add_resource(ToolApiProviderAddApi, '/workspaces/current/tool-provider/api/add')api.add_resource(ToolApiProviderGetRemoteSchemaApi, '/workspaces/current/tool-provider/api/remote')api.add_resource(ToolApiProviderListToolsApi, '/workspaces/current/tool-provider/api/tools')api.add_resource(ToolApiProviderUpdateApi, '/workspaces/current/tool-provider/api/update')api.add_resource(ToolApiProviderDeleteApi, '/workspaces/current/tool-provider/api/delete')api.add_resource(ToolApiProviderGetApi, '/workspaces/current/tool-provider/api/get')api.add_resource(ToolApiProviderSchemaApi, '/workspaces/current/tool-provider/api/schema')api.add_resource(ToolApiProviderPreviousTestApi, '/workspaces/current/tool-provider/api/test/pre')api.add_resource(ToolBuiltinListApi, '/workspaces/current/tools/builtin')api.add_resource(ToolApiListApi, '/workspaces/current/tools/api')
 |