MediaWiki MCP adapter

by lucamauri
Verified

remote-capable server

The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.

Integrations

  • Provides access to WikiBase APIs, with the default API base URL set to Wikidata's API endpoint for programmatic interaction.

  • Enables fetching and editing MediaWiki pages with the default API base URL set to Wikipedia's API endpoint, supporting page content retrieval and editing operations.

MediaWikiAdapter

A custom Model Context Protocol (MCP) adapter for interacting with MediaWiki and WikiBase APIs. This adapter allows you to fetch and edit MediaWiki pages programmatically using the MCP framework.

Features

  • Fetch the content of a MediaWiki page.
  • Edit a MediaWiki page with new content and an optional summary.
  • Configurable API base URLs for different MediaWiki and WikiBase instances.

Requirements

  • Node.js (v16 or later)
  • TypeScript (for development)
  • MediaWiki instance with API access enabled

Installation

  1. Clone the repository:
git clone https://github.com/yourusername/mediawikiadapter.git cd mediawikiadapter
  1. Install dependencies:
    npm install
  2. Build the project:
    npm run build

Usage

Configure the Adapter

You can configure the adapter to use custom MediaWiki and WikiBase API endpoints:

server.configure({ mediaWikiAPIBase: "https://my.mediawiki.instance/api.php", wikiBaseAPIBase: "https://my.wikibase.instance/api.php", });

Start the MCP Server

Run the MCP server using the following command:

node build/index.js

Resources

getPageContent

Fetches the content of a MediaWiki page.

  • Input Schema:
{ "title": "string" }
  • Output Schema:
    { "content": "string" }

Example Usage:

const response = await server.callResource("getPageContent", { title: "Main Page", }); console.log(response.content);

Tools

editPage

Edits a MediaWiki page with new content.

  • Input Schema:
{ "title": "string", "content": "string", "summary": "string (optional)" }
  • Output Schema:
{ "success": "boolean" }

Example Usage:

const response = await server.callTool("editPage", { title: "Main Page", content: "Updated content for the page.", summary: "Updated via MediaWikiAdapter", }); console.log(response.success ? "Edit successful" : "Edit failed");

Development

Run in Development Mode

To run the project in development mode with TypeScript:

npm run dev

Linting

Run the linter to check for code quality:

npm run lint

Testing

Currently, no tests are implemented. You can add tests to the test directory and run them using:

npm test

Configuration

The adapter uses the following default API base URLs:

You can override these defaults using the server.configure() method.


Contributing

Contributions are welcome! Please follow these steps:

  1. Fork the repository.
  2. Create a new branch for your feature or bug fix.
  3. Submit a pull request with a detailed description of your changes.

License

This project is licensed under the LGPL-3.0-or-later license. See the LICENSE file for details.


Author

Created by Luca Mauri.

-
security - not tested
A
license - permissive license
-
quality - not tested

A custom Model Context Protocol adapter for MediaWiki and WikiBase APIs

  1. Features
    1. Requirements
      1. Installation
        1. Usage
          1. Configure the Adapter
          2. Start the MCP Server
          3. Resources
          4. Tools
        2. Development
          1. Run in Development Mode
          2. Linting
          3. Testing
        3. Configuration
          1. Contributing
            1. License
              1. Author
                ID: 2kd2tl3hsl