mcp-douban-server
v1.0.0
Published
MCP Server for Douban books, movies, and groups interaction
Downloads
12
Maintainers
Readme
Douban MCP Server
This MCP server provides functionality to search and interact with Douban content including books, movies, and group discussions.
Features
- Search Books: Search books by title keywords or ISBN
- Search Movies: Search movies by title or keywords
- Get Movie Reviews: Fetch reviews for a specific movie
- Browse Content: Open book or movie pages in your default browser
- Group Topics: List and filter topics from Douban groups
- Topic Details: Get detailed content of specific group topics
Tools
The server provides the following tools that can be called through MCP:
1. Search Books
// Tool name: search-book
{
q: "Python", // Optional: Search by keyword
isbn: "9787501524044" // Optional: Search by ISBN
}One of q or isbn must be provided.
2. Search Movies
// Tool name: search-movie
{
q: "Inception"; // Required: Search by title or keyword
}3. Get Movie Reviews
// Tool name: get-movie-reviews
{
id: "1889243"; // Required: Douban movie ID
}4. Browse Content
// Tool name: browse
{
id: "1889243", // Required: Douban item ID
type: "movie" // Optional: "book" (default) or "movie"
}5. List Group Topics
// Tool name: list-group-topics
{
id: "732764", // Optional: Douban group ID (default: 732764)
tags: ["python", "web"], // Optional: Filter by tags
from_date: "2024-01-01" // Optional: Filter by date (from this date onward)
}6. Get Group Topic Detail
// Tool name: get-group-topic-detail
{
id: "123456789"; // Required: Douban group topic ID
}Response Format
All tools return responses in the following format:
{
content: [
{
type: "text",
text: "Response content in markdown format",
},
];
}Getting Started
- Clone the repository
- Install dependencies:
npm install - Build the server:
npm run build
Usage
To use the server, you can run it directly:
npm startThis will start the Douban MCP Server running on stdio.
Usage with Desktop App
To integrate this server with a desktop app, add the following to your app's server configuration:
{
"mcpServers": {
"douban-mcp": {
"command": "node",
"args": ["{ABSOLUTE PATH TO FILE HERE}/dist/index.js"],
"env": {
"COOKIE": "bid=;ck=;dbcl2=;frodotk_db=;" // get cookie value from Douban website
}
}
}
}Configuration
You can configure various options through environment variables:
# API Configuration
export COOKIE="bid=;ck=;dbcl2=;frodotk_db=;" # Your Douban cookie value for authenticated requestsDevelopment
- Run
npm run devto start the TypeScript compiler in watch mode - Run
npm testto run tests
Douban API Integration
This server uses several Douban APIs:
- Book API - Searches for books by keyword or ISBN
- Movie API - Searches for movies and retrieves reviews
- Group API - Accesses group topics and details
Error Handling
All tools include comprehensive error handling that will provide clear error messages when issues occur, such as:
- Invalid parameters
- Not found errors
- API request failures
- Authentication issues
License
This project is licensed under the MIT License.
