eigent/server/app/component/validator/McpServer.py
puzhen 63b723e1cf merge main into feat/ask_with_single_agent
Resolve conflicts in:
- server/uv.lock (revision number, greenlet wheel format)
- src/store/chatStore.ts (merge target/displayContent and executionId/projectId params)
- src/components/ChatBox/BottomBox/InputBox.tsx (merge mention and trigger/expanded features)
- src/components/ChatBox/index.tsx (merge mention/direct-agent features with new unified layout)
2026-03-03 11:45:42 +00:00

47 lines
1.4 KiB
Python

# ========= Copyright 2025-2026 @ Eigent.ai All Rights Reserved. =========
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ========= Copyright 2025-2026 @ Eigent.ai All Rights Reserved. =========
from pydantic import BaseModel, ValidationError
class McpServerItem(BaseModel):
command: str
args: list[str]
env: dict[str, str] | None = None
class McpServersModel(BaseModel):
mcpServers: dict[str, McpServerItem]
class McpRemoteServer(BaseModel):
server_name: str
server_url: str
def validate_mcp_servers(data: dict):
try:
model = McpServersModel.model_validate(data)
return True, model
except ValidationError as e:
return False, e.errors()
def validate_mcp_remote_servers(data: dict):
try:
model = McpRemoteServer.model_validate(data)
return True, model
except ValidationError as e:
return False, e.errors()