TinaMCP
The TinaCMS MCP Server is a C# implementation of a Model Context Protocol server, allowing interaction with TinaCMS project content files for AI models and other clients. It offers operations like listing and managing documents within the project using standard MCP protocols.
TinaCMS MCP Server (C#)
This project implements a standalone Model Context Protocol (MCP) server using the official C# SDK (modelcontextprotocol/csharp-sdk
). Its purpose is to expose tools that allow interaction with content files managed by a TinaCMS project repository.
This enables AI models or other MCP clients to list, read, create, update, and delete content files within a TinaCMS site via the standardized MCP.
Features
- Connects to a local TinaCMS project directory.
- Uses standard MCP Stdio transport for communication.
- Provides tools for basic content management operations:
- Listing collections (directories under
/content
). - Listing documents within a collection (non-recursive and recursive).
- Reading document content.
- Reading document frontmatter (metadata).
- Creating new documents.
- Updating existing documents (full content replace).
- Updating document frontmatter (metadata merge).
- Deleting documents.
- Moving/Renaming documents.
- Copying documents.
- Reading the TinaCMS generated schema (
.tina/schema.json
).
- Listing collections (directories under
- Includes basic path validation and security checks.
Prerequisites
- .NET 8 SDK (or later): Required to build and run the C# server.
- Node.js and npm/npx: Required to run the MCP Inspector tool for testing.
- A TinaCMS Project: You need a local TinaCMS project whose content you want this server to manage.
Setup
- Clone/Download: Get the source code for this project.
- Configure Root Path:
- Open the
appsettings.json
file. - Locate the
TinaProject
section. - IMPORTANT: Replace the sample path provided for
RootPath
with the full, absolute path of your target TinaCMS project's root directory (the one containing the.tina
folder). - Use forward slashes (
/
) for the path separators (recommended for cross-platform compatibility) or double backslashes (\\
) if preferred on Windows.
{ "Logging": { ... }, "TinaProject": { "RootPath": "/path/to/your/tina-project" } }
- Open the
- Restore Dependencies: Open a terminal in the
TinaMcpServer
project directory and run:dotnet restore
Development
- Build: To compile the project:
dotnet build
- Run Locally (for testing): The server is designed to be run by an MCP client (like the Inspector). Running it directly isn't very useful, but you can start it with:
or by running the compiled DLL:dotnet run
The server will start and wait for an MCP client to connect via standard input/output. It will likely exit immediately or show JSON errors if run without a client.dotnet bin/Debug/net8.0/TinaMcpServer.dll
Testing with MCP Inspector
The recommended way to test the server and its tools is using the official MCP Inspector.
- Ensure the project is built: Run
dotnet build
if you haven't already. - Run the Inspector: In your terminal (in the
TinaMcpServer
project directory), run the following command. This tells the Inspector to launch your compiled server DLL usingdotnet
:npx @modelcontextprotocol/inspector dotnet bin/Debug/net8.0/TinaMcpServer.dll
- Open Inspector UI: The command will output a URL (e.g.,
http://127.0.0.1:6274
). Open this URL in your web browser. - Connect: Click the "Connect" button for the detected
TinaMcpServer
. - Use Tools:
- Navigate to the "Tools" tab.
- Click "List Tools" to see all available tools.
- Click on a specific tool to see its description and arguments.
- Fill in the required arguments and click "Run Tool".
- Observe the results and check the terminal running the Inspector for logs from the C# server.
Available Tools
(Descriptions are abbreviated here; see tool attributes in code for full details)
ListTinaCollections()
: Lists collection directories under/content
.ListCollectionDocuments(collection)
: Lists files directly within a collection directory.ListDocumentsRecursive(collection)
: Lists all files within a collection, including subdirectories.GetTinaDocument(collection, relativePath)
: Gets the full text content of a document.CreateTinaDocument(collection, relativePath, content)
: Creates a new document; fails if it exists.UpdateTinaDocument(collection, relativePath, content)
: Overwrites an existing document; fails if it doesn't exist.DeleteTinaDocument(collection, relativePath)
: Deletes an existing document; fails if it doesn't exist.MoveDocument(collection, oldRelativePath, newRelativePath)
: Moves/renames a document.CopyDocument(collection, sourceRelativePath, destinationRelativePath)
: Copies a document.GetDocumentMetadata(collection, relativePath)
: Gets YAML frontmatter as a JSON string.UpdateDocumentMetadata(collection, relativePath, metadataUpdatesJson)
: Adds/updates frontmatter fields from a JSON object.GetCollectionSchemaInfo(collection)
: Reads the.tina/schema.json
file content.
Potential Future Enhancements
- Configuration for the assumed
/content
directory name. - More granular update operations (e.g., partial updates instead of full replace).
- Support for different frontmatter formats (e.g., JSON, TOML) if needed.
- More robust schema parsing/interaction.
- Different transport options (e.g., HTTP/SSE).