TIB MCP Server
A Model Context Protocol server for scholarly tools, enabling AI assistants to interact with scholarly data and services via discoverable tools.
README
TIB MCP
A Model Context Protocol (MCP) server for scholarly tools, built with FastMCP. MCP is an open standard that lets AI assistants interact with external tools and data sources through a unified protocol. This server exposes scholarly tools that any MCP-compatible client can discover and invoke.
Prerequisites
- Python 3.14+ — the project includes a
.python-versionfile for tool compatibility - uv — used as the package manager, build system, and script runner
Quick Start
# Clone the repository
git clone https://gitlab.com/TIBHannover/orkg/tib-aissistant/tib-mcp.git
cd tib-mcp
# Create your local environment file
cp .env.example .env
# Install all dependencies (including dev tools)
uv sync
# Start the server
uv run python main.py
By default the server starts in streamable-http mode, which is suitable for networked or remote access. For local MCP client integrations (e.g. Claude Desktop, VS Code with Copilot), you can switch to stdio mode.
Architecture
The runtime is split into small layers:
main.pyandserver/main.pyare entry points that start the FastMCP server.server/app.pybuilds the application instance (create_app) and registers tools.server/core/contains environment-based configuration (Settings, transport normalization).server/tools/exposes MCP tools and mounts them by namespace.server/services/contains business logic used by tools.server/utils/contains runtime helpers (for example transport-specific run kwargs).
Configuration
All configuration is done through environment variables. A .env file in the project root is automatically loaded on startup via python-dotenv. See .env.example for a documented template.
| Variable | Description | Default | Valid Values |
|---|---|---|---|
MCP_SERVER_NAME |
Server Name | TIB MCP Server |
any name |
MCP_TRANSPORT |
Transport protocol | streamable-http |
stdio, http, sse, streamable-http |
MCP_HOST |
Bind address (non-stdio transports) | 127.0.0.1 |
Any valid host/IP |
MCP_PORT |
Port number (non-stdio transports) | 8000 |
Any valid port |
MCP_LOG_LEVEL |
Logging verbosity | INFO |
DEBUG, INFO, WARNING, ERROR, CRITICAL |
Running the Server
stdio Mode
Designed for direct integration with AI clients. The client launches the server as a subprocess and communicates over stdin/stdout:
uv run python main.py
For example, to configure this server in an MCP client, point it at:
{
"mcpServers": {
"tib-mcp": {
"command": "uv",
"args": ["run", "python", "main.py"],
"cwd": "/path/to/tib-mcp"
}
}
}
HTTP Mode
For networked or remote access, use the streamable-http transport:
# Via .env file
MCP_TRANSPORT=streamable-http
# Or inline
MCP_TRANSPORT=streamable-http uv run python main.py
The server will be available at http://127.0.0.1:8000/mcp.
Try It with MCP Inspector
You can play around with the server using @modelcontextprotocol/inspector:
# Inspect via stdio (launches this server as a subprocess)
npx @modelcontextprotocol/inspector uv run python main.py
If your server is already running in streamable-http mode:
npx @modelcontextprotocol/inspector
Then connect to http://127.0.0.1:8000/mcp from the Inspector UI.
Docker
The project includes a production-ready Dockerfile that defaults to streamable-http transport on 0.0.0.0:8000:
# Build the image
docker build -t tib-mcp .
# Run the container
docker run -p 8000:8000 tib-mcp
Override configuration with environment variables:
docker run -e MCP_LOG_LEVEL=DEBUG -p 8000:8000 tib-mcp
Running Tests
uv run pytest
The test suite is organized into four categories:
| Category | Location | Description |
|---|---|---|
| Unit | tests/tools/test_sum.py |
Direct function-level tests for each tool |
| Config | tests/test_config.py |
Validates environment variable defaults and overrides |
| Contract | tests/test_contract.py |
Verifies tool metadata, descriptions, and JSON schemas |
| Integration | tests/test_integration.py |
End-to-end MCP client/server communication tests |
For verbose output:
uv run pytest -v
Project Structure
tib-mcp/
├── main.py # Root entry point for running the MCP server
├── server/
│ ├── __init__.py
│ ├── app.py # App factory (create_app / get_application)
│ ├── main.py # Server module entry point + exported runtime constants
│ ├── core/
│ │ ├── __init__.py
│ │ └── config.py # Environment config + transport normalization
│ ├── services/
│ │ ├── __init__.py
│ │ └── sum.py # Sum service logic
│ ├── tools/
│ │ ├── __init__.py # Tool mounting (register_tools)
│ │ └── sum.py # Sum MCP sub-server and tool definition
│ └── utils/
│ ├── __init__.py
│ └── runtime.py # Runtime helpers (run kwargs per transport)
├── tests/
│ ├── __init__.py
│ ├── conftest.py # Shared fixtures (mcp_app, mcp_client)
│ ├── test_config.py # Configuration behavior tests
│ ├── test_contract.py # Tool metadata/schema contract tests
│ ├── test_integration.py # MCP client/server integration tests
│ └── tools/
│ ├── __init__.py
│ └── test_sum.py # Unit tests for sum behavior
├── pyproject.toml # Dependencies + tool configuration
├── uv.lock # Dependency lock file
├── Dockerfile # Container image definition
├── .dockerignore
├── .env.example # Environment variable template
├── .pre-commit-config.yaml # Pre-commit hooks (Ruff + checks)
├── AGENTS.md # Repository instructions for coding agents
├── CLAUDE.md
├── LICENSE
└── README.md
Development
Pre-commit Hooks
The project uses Ruff for linting and formatting, configured via pre-commit:
uv run pre-commit install
This runs automatically on every commit, or manually with:
uv run pre-commit run --all-files
Adding a New Tool
Tools in this project follow the same pattern as sum: a service layer for logic, and a FastMCP sub-server for exposure.
- Create the service in
server/services/my_tool.py:
class MyToolService:
def do_something(self, param: str) -> str:
return param.strip().upper()
- Export the service in
server/services/__init__.py:
from server.services.my_tool import MyToolService
__all__ = ["SumService", "MyToolService"]
- Create the MCP tool sub-server in
server/tools/my_tool.py:
from fastmcp import FastMCP
from server.services import MyToolService
server = FastMCP("my_tool")
my_tool_service = MyToolService()
@server.tool()
def do_something(param: str) -> str:
"""Short description of what this tool does.
Args:
param: Description of the parameter.
Returns:
Description of the return value.
"""
return my_tool_service.do_something(param)
Type hints define the input schema, and the docstring is exposed to MCP clients as tool description.
- Mount the tool in
server/tools/__init__.py:
from fastmcp import FastMCP
from server.tools.my_tool import server as my_tool_server
from server.tools.sum import server as sum_server
def register_tools(app: FastMCP) -> None:
app.mount(sum_server, namespace="sum")
app.mount(my_tool_server, namespace="my_tool")
With namespace mounting, this tool is discoverable as my_tool_do_something.
- Add/update tests:
- Unit test in
tests/tools/test_my_tool.py(direct function/service behavior). - Contract test in
tests/test_contract.py(tool name, description, schema, tool count). - Integration test in
tests/test_integration.py(call the tool via MCP client).
Then run:
uv run pytest
uv run pre-commit run --all-files
License
This project is licensed under the MIT License. © 2026 ORKG/TIB Team
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。