Spaces:
Configuration error
Configuration error
File size: 8,588 Bytes
447ebeb |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 |
import React, { useState } from "react";
import {
Modal,
Tooltip,
Form,
Select,
message,
Button as AntdButton,
} from "antd";
import { InfoCircleOutlined } from "@ant-design/icons";
import { Button, TextInput } from "@tremor/react";
import { createMCPServer } from "../networking";
import { MCPServer } from "./types";
import { isAdminRole } from "@/utils/roles";
interface CreateMCPServerProps {
userRole: string;
accessToken: string | null;
onCreateSuccess: (newMcpServer: MCPServer) => void;
}
const CreateMCPServer: React.FC<CreateMCPServerProps> = ({
userRole,
accessToken,
onCreateSuccess,
}) => {
const [form] = Form.useForm();
const [isLoading, setIsLoading] = useState(false);
const handleCreate = async (formValues: Record<string, any>) => {
setIsLoading(true);
try {
console.log(`formValues: ${JSON.stringify(formValues)}`);
if (accessToken != null) {
const response: MCPServer = await createMCPServer(
accessToken,
formValues
);
message.success("MCP Server created successfully");
form.resetFields();
setModalVisible(false);
onCreateSuccess(response);
}
} catch (error) {
message.error("Error creating MCP Server: " + error, 20);
} finally {
setIsLoading(false);
}
};
// state
const [isModalVisible, setModalVisible] = useState(false);
const handleCancel = () => {
form.resetFields();
setModalVisible(false);
};
// rendering
if (!isAdminRole(userRole)) {
return null;
}
return (
<div>
<Button
className="mx-auto"
onClick={() => setModalVisible(true)}
>
+ Add New MCP Server
</Button>
<Modal
title={
<div className="flex items-center space-x-3 pb-4 border-b border-gray-100">
<div className="w-10 h-10 bg-white rounded-lg flex items-center justify-center shadow-sm border border-gray-200">
<img
src="/assets/logos/mcp_logo.png"
alt="MCP Logo"
className="w-8 h-8 object-contain"
/>
</div>
<div>
<h2 className="text-xl font-semibold text-gray-900">Add New MCP Server</h2>
<p className="text-sm text-gray-500 mt-1">Configure your MCP server connection</p>
</div>
</div>
}
open={isModalVisible}
width={1000}
onCancel={handleCancel}
footer={null}
className="top-8"
styles={{
body: { padding: '24px' },
header: { padding: '24px 24px 0 24px', border: 'none' },
}}
>
<div className="mt-6">
<Form
form={form}
onFinish={handleCreate}
layout="vertical"
className="space-y-6"
>
<div className="grid grid-cols-1 gap-6">
<Form.Item
label={
<span className="text-sm font-medium text-gray-700 flex items-center">
MCP Server Name
<Tooltip title="Best practice: Use a descriptive name that indicates the server's purpose (e.g., 'GitHub Integration', 'Email Service')">
<InfoCircleOutlined className="ml-2 text-blue-400 hover:text-blue-600 cursor-help" />
</Tooltip>
</span>
}
name="alias"
rules={[
{ required: false, message: "Please enter a server name" },
]}
>
<TextInput
placeholder="e.g., GitHub MCP, Zapier MCP, etc."
className="rounded-lg border-gray-300 focus:border-blue-500 focus:ring-blue-500"
/>
</Form.Item>
<Form.Item
label={<span className="text-sm font-medium text-gray-700">Description</span>}
name="description"
rules={[
{
required: false,
message: "Please enter a server description",
},
]}
>
<TextInput
placeholder="Brief description of what this server does"
className="rounded-lg border-gray-300 focus:border-blue-500 focus:ring-blue-500"
/>
</Form.Item>
<Form.Item
label={
<span className="text-sm font-medium text-gray-700">
MCP Server URL <span className="text-red-500">*</span>
</span>
}
name="url"
rules={[
{ required: true, message: "Please enter a server URL" },
{ type: 'url', message: "Please enter a valid URL" }
]}
>
<TextInput
placeholder="https://your-mcp-server.com"
className="rounded-lg border-gray-300 focus:border-blue-500 focus:ring-blue-500"
/>
</Form.Item>
<div className="grid grid-cols-2 gap-4">
<Form.Item
label={
<span className="text-sm font-medium text-gray-700">
Transport Type <span className="text-red-500">*</span>
</span>
}
name="transport"
rules={[{ required: true, message: "Please select a transport type" }]}
>
<Select
placeholder="Select transport"
className="rounded-lg"
size="large"
>
<Select.Option value="sse">Server-Sent Events (SSE)</Select.Option>
<Select.Option value="http">HTTP</Select.Option>
</Select>
</Form.Item>
<Form.Item
label={
<span className="text-sm font-medium text-gray-700">
Authentication <span className="text-red-500">*</span>
</span>
}
name="auth_type"
rules={[{ required: true, message: "Please select an auth type" }]}
>
<Select
placeholder="Select auth type"
className="rounded-lg"
size="large"
>
<Select.Option value="none">None</Select.Option>
<Select.Option value="api_key">API Key</Select.Option>
<Select.Option value="bearer_token">Bearer Token</Select.Option>
<Select.Option value="basic">Basic Auth</Select.Option>
</Select>
</Form.Item>
</div>
<Form.Item
label={
<span className="text-sm font-medium text-gray-700 flex items-center">
MCP Version <span className="text-red-500 ml-1">*</span>
<Tooltip title="Select the MCP specification version your server supports">
<InfoCircleOutlined className="ml-2 text-gray-400 hover:text-gray-600" />
</Tooltip>
</span>
}
name="spec_version"
rules={[
{ required: true, message: "Please select a spec version" },
]}
>
<Select
placeholder="Select MCP version"
className="rounded-lg"
size="large"
>
<Select.Option value="2025-03-26">2025-03-26 (Latest)</Select.Option>
<Select.Option value="2024-11-05">2024-11-05</Select.Option>
</Select>
</Form.Item>
</div>
<div className="flex items-center justify-end space-x-3 pt-6 border-t border-gray-100">
<Button
variant="secondary"
onClick={handleCancel}
>
Cancel
</Button>
<Button
variant="primary"
loading={isLoading}
>
{isLoading ? 'Creating...' : 'Create MCP Server'}
</Button>
</div>
</Form>
</div>
</Modal>
</div>
);
};
export default CreateMCPServer; |