123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- import json
- from flask import request
- from flask_login import current_user
- from flask_restful import Resource
- from controllers.console import api
- from controllers.console.app.wraps import get_app_model
- from controllers.console.setup import setup_required
- from controllers.console.wraps import account_initialization_required
- from core.agent.entities import AgentToolEntity
- from core.tools.tool_manager import ToolManager
- from core.tools.utils.configuration import ToolParameterConfigurationManager
- from events.app_event import app_model_config_was_updated
- from extensions.ext_database import db
- from libs.login import login_required
- from models.model import AppMode, AppModelConfig
- from services.app_model_config_service import AppModelConfigService
- class ModelConfigResource(Resource):
- @setup_required
- @login_required
- @account_initialization_required
- @get_app_model(mode=[AppMode.AGENT_CHAT, AppMode.CHAT, AppMode.COMPLETION])
- def post(self, app_model):
-
- """Modify app model config"""
- # validate config
- model_configuration = AppModelConfigService.validate_configuration(
- tenant_id=current_user.current_tenant_id,
- config=request.json,
- app_mode=AppMode.value_of(app_model.mode)
- )
- new_app_model_config = AppModelConfig(
- app_id=app_model.id,
- )
- new_app_model_config = new_app_model_config.from_model_config_dict(model_configuration)
- if app_model.mode == AppMode.AGENT_CHAT.value or app_model.is_agent:
- # get original app model config
- original_app_model_config: AppModelConfig = db.session.query(AppModelConfig).filter(
- AppModelConfig.id == app_model.app_model_config_id
- ).first()
- agent_mode = original_app_model_config.agent_mode_dict
- # decrypt agent tool parameters if it's secret-input
- parameter_map = {}
- masked_parameter_map = {}
- tool_map = {}
- for tool in agent_mode.get('tools') or []:
- if not isinstance(tool, dict) or len(tool.keys()) <= 3:
- continue
- agent_tool_entity = AgentToolEntity(**tool)
- # get tool
- try:
- tool_runtime = ToolManager.get_agent_tool_runtime(
- tenant_id=current_user.current_tenant_id,
- app_id=app_model.id,
- agent_tool=agent_tool_entity,
- )
- manager = ToolParameterConfigurationManager(
- tenant_id=current_user.current_tenant_id,
- tool_runtime=tool_runtime,
- provider_name=agent_tool_entity.provider_id,
- provider_type=agent_tool_entity.provider_type,
- identity_id=f'AGENT.{app_model.id}'
- )
- except Exception as e:
- continue
- # get decrypted parameters
- if agent_tool_entity.tool_parameters:
- parameters = manager.decrypt_tool_parameters(agent_tool_entity.tool_parameters or {})
- masked_parameter = manager.mask_tool_parameters(parameters or {})
- else:
- parameters = {}
- masked_parameter = {}
- key = f'{agent_tool_entity.provider_id}.{agent_tool_entity.provider_type}.{agent_tool_entity.tool_name}'
- masked_parameter_map[key] = masked_parameter
- parameter_map[key] = parameters
- tool_map[key] = tool_runtime
- # encrypt agent tool parameters if it's secret-input
- agent_mode = new_app_model_config.agent_mode_dict
- for tool in agent_mode.get('tools') or []:
- agent_tool_entity = AgentToolEntity(**tool)
- # get tool
- key = f'{agent_tool_entity.provider_id}.{agent_tool_entity.provider_type}.{agent_tool_entity.tool_name}'
- if key in tool_map:
- tool_runtime = tool_map[key]
- else:
- try:
- tool_runtime = ToolManager.get_agent_tool_runtime(
- tenant_id=current_user.current_tenant_id,
- app_id=app_model.id,
- agent_tool=agent_tool_entity,
- )
- except Exception as e:
- continue
- manager = ToolParameterConfigurationManager(
- tenant_id=current_user.current_tenant_id,
- tool_runtime=tool_runtime,
- provider_name=agent_tool_entity.provider_id,
- provider_type=agent_tool_entity.provider_type,
- identity_id=f'AGENT.{app_model.id}'
- )
- manager.delete_tool_parameters_cache()
- # override parameters if it equals to masked parameters
- if agent_tool_entity.tool_parameters:
- if key not in masked_parameter_map:
- continue
-
- for masked_key, masked_value in masked_parameter_map[key].items():
- if masked_key in agent_tool_entity.tool_parameters and \
- agent_tool_entity.tool_parameters[masked_key] == masked_value:
- agent_tool_entity.tool_parameters[masked_key] = parameter_map[key].get(masked_key)
- # encrypt parameters
- if agent_tool_entity.tool_parameters:
- tool['tool_parameters'] = manager.encrypt_tool_parameters(agent_tool_entity.tool_parameters or {})
- # update app model config
- new_app_model_config.agent_mode = json.dumps(agent_mode)
- db.session.add(new_app_model_config)
- db.session.flush()
- app_model.app_model_config_id = new_app_model_config.id
- db.session.commit()
- app_model_config_was_updated.send(
- app_model,
- app_model_config=new_app_model_config
- )
- return {'result': 'success'}
- api.add_resource(ModelConfigResource, '/apps/<uuid:app_id>/model-config')
|