requarks-wiki-mcp
An MCP server that enables AI agents to interact with Wiki.js as a knowledge base through a comprehensive set of 29 tools for content retrieval and management. It supports full-text search, page versioning, and asset browsing with optional write operations secured by safety gates.
README
requarks-wiki-mcp
MCP server for a Wiki.js instance that lets agents use it like a knowledge base.
Features:
- 29 tools (19 read + 10 write) covering pages, comments, tags, assets, users, navigation, and system info.
- Search, list, and browse pages for retrieval workflows (RAG-like usage).
- Fetch page content by path or page ID, view version history and restore previous versions.
- Browse site hierarchy with page tree, page links graph, and navigation structure.
- Full comment system: list, read, create, update, and delete comments on pages.
- Asset and folder browsing for media file discovery.
- User context: current user profile and user search.
- System diagnostics: version info, site config, and navigation tree.
- Tag management: list, search, update, and delete tags.
- Optional page create/update/delete/move/restore tools with explicit safety gates.
- Built-in resources: markdown syntax guide, Mermaid diagram guide, and API permissions guide.
- Typed error taxonomy with LLM-friendly error messages.
- GraphQL client with timeout, exponential-backoff retry, and request correlation.
- Security hardening: sensitive field filtering, URL validation, input length limits.
Requirements
- Node.js 20+
- A reachable Wiki.js hostname
- Wiki.js API key (JWT) with proper permissions
Setup
cp .env.example .env
npm install
Configure .env:
WIKI_BASE_URL=https://your-wiki-hostname
WIKI_API_TOKEN=your_wikijs_api_key_jwt
WIKI_GRAPHQL_PATH=/graphql
WIKI_DEFAULT_LOCALE=en
WIKI_DEFAULT_EDITOR=markdown
# Mutating operations are disabled by default
WIKI_MUTATIONS_ENABLED=false
# Optional extra safety gate for writes. If set, write tools must pass matching confirm.
WIKI_MUTATION_CONFIRM_TOKEN=
WIKI_MUTATION_DRY_RUN=true
# Comma-separated path prefixes without leading slash (empty = no prefix restriction)
WIKI_ALLOWED_MUTATION_PATH_PREFIXES=
# HTTP resilience
WIKI_HTTP_TIMEOUT_MS=15000
WIKI_HTTP_MAX_RETRIES=2
Environment variable reference:
| Variable | Required | Default | Description |
|---|---|---|---|
WIKI_BASE_URL |
Yes | - | Base Wiki.js URL (for example, https://wiki.example.com). |
WIKI_API_TOKEN |
Yes | - | Wiki.js API key JWT used in Authorization: Bearer .... |
WIKI_GRAPHQL_PATH |
No | /graphql |
GraphQL endpoint path appended to WIKI_BASE_URL. |
WIKI_DEFAULT_LOCALE |
No | en |
Default locale used when tool input does not provide locale. |
WIKI_DEFAULT_EDITOR |
No | markdown |
Default editor used for page creation when not specified. |
WIKI_MUTATIONS_ENABLED |
No | false |
Enables all write tools (page, comment, and tag mutations) when set to true. |
WIKI_MUTATION_CONFIRM_TOKEN |
No | `` (empty) | Optional extra safety gate. When set, write tool calls must provide matching confirm. |
WIKI_MUTATION_DRY_RUN |
No | true |
When true, mutation tools return preview only and do not write to Wiki.js. |
WIKI_ALLOWED_MUTATION_PATH_PREFIXES |
No | `` (empty) | Comma-separated path prefixes (without leading slash) allowed for mutations. Empty means no prefix restriction. |
WIKI_HTTP_TIMEOUT_MS |
No | 15000 |
HTTP request timeout in milliseconds (including body reads). Minimum 1. |
WIKI_HTTP_MAX_RETRIES |
No | 2 |
Max retries for transient read failures (408, 502-504). Mutations are never retried. Minimum 0. |
Wiki.js prerequisite (GraphQL + API key):
- This MCP uses Wiki.js GraphQL internally.
- In Wiki.js admin, go to
Administration -> APIand enable API access. - Create an API key and set it as
WIKI_API_TOKEN.
MCP Client Config Example (~/.mcp.json)
{
"mcpServers": {
"requarks-wiki": {
"command": "npx",
"args": ["-y", "@yowu-dev/requarks-wiki-mcp@latest"],
"env": {
"WIKI_BASE_URL": "https://wiki.your-domain.dev",
"WIKI_API_TOKEN": "your_wikijs_api_key_jwt",
"WIKI_GRAPHQL_PATH": "/graphql",
"WIKI_DEFAULT_LOCALE": "en",
"WIKI_DEFAULT_EDITOR": "markdown",
"WIKI_MUTATIONS_ENABLED": "true",
"WIKI_MUTATION_CONFIRM_TOKEN": "CONFIRM_UPDATE",
"WIKI_MUTATION_DRY_RUN": "false",
"WIKI_ALLOWED_MUTATION_PATH_PREFIXES": "",
"WIKI_HTTP_TIMEOUT_MS": "15000",
"WIKI_HTTP_MAX_RETRIES": "2"
}
}
}
}
Register MCP Via Local Path (Without npm Publish)
You can register this MCP server directly from your local project path without publishing/installing from npm.
- Build in this repository
npm install
npm run build
- Register local absolute path in
~/.mcp.json
{
"mcpServers": {
"requarks-wiki-local": {
"command": "node",
"args": ["/absolute/path/to/requarks-wiki-mcp/dist/index.js"],
"env": {
"WIKI_BASE_URL": "https://wiki.your-domain.dev",
"WIKI_API_TOKEN": "your_wikijs_api_key_jwt",
"WIKI_GRAPHQL_PATH": "/graphql",
"WIKI_DEFAULT_LOCALE": "en",
"WIKI_DEFAULT_EDITOR": "markdown",
"WIKI_MUTATIONS_ENABLED": "true",
"WIKI_MUTATION_CONFIRM_TOKEN": "",
"WIKI_MUTATION_DRY_RUN": "false",
"WIKI_ALLOWED_MUTATION_PATH_PREFIXES": "",
"WIKI_HTTP_TIMEOUT_MS": "15000",
"WIKI_HTTP_MAX_RETRIES": "2"
}
}
}
}
Notes:
- Always use an absolute path.
- Re-run
npm run buildafter code changes sodist/index.jsstays up to date.
Run
Development:
npm run dev
Build + run:
npm run build
npm start
MCP Tools
Read Tools (19)
Pages:
| Tool | Description |
|---|---|
wikijs_search_pages |
Full-text search across wiki pages. |
wikijs_list_pages |
List pages with optional locale filter and limit. |
wikijs_get_page_by_path |
Get full page content by path + locale. |
wikijs_get_page_by_id |
Get full page content by numeric ID. |
wikijs_get_page_tree |
Browse site hierarchy (folders, pages, or both). |
wikijs_get_page_history |
View edit history trail for a page. |
wikijs_get_page_version |
Get a specific version's full content. |
wikijs_get_page_links |
Get page link relationships (knowledge graph). |
Tags:
| Tool | Description |
|---|---|
wikijs_list_tags |
List all tags for content taxonomy discovery. |
wikijs_search_tags |
Search for tags matching a query string. |
Comments:
| Tool | Description |
|---|---|
wikijs_list_comments |
List all comments for a page by path and locale. |
wikijs_get_comment |
Get a single comment by ID. |
System & Navigation:
| Tool | Description |
|---|---|
wikijs_get_system_info |
Wiki.js version, database type, and usage statistics. |
wikijs_get_navigation |
Navigation tree structure. |
wikijs_get_site_config |
Site configuration (non-sensitive fields). |
Assets:
| Tool | Description |
|---|---|
wikijs_list_assets |
List assets with optional folder and kind filter. |
wikijs_list_asset_folders |
List asset folders. |
Users:
| Tool | Description |
|---|---|
wikijs_get_current_user |
Get the currently authenticated API user's profile. |
wikijs_search_users |
Search users by name or email. |
Write Tools (10, disabled unless WIKI_MUTATIONS_ENABLED=true)
Page Mutations:
| Tool | Description |
|---|---|
wikijs_create_page |
Create a new page with content, tags, and metadata. |
wikijs_update_page |
Update an existing page by ID. |
wikijs_delete_page |
Delete a page by ID. May need manage:pages or delete:pages. |
wikijs_move_page |
Move/rename a page to a new path or locale. |
wikijs_restore_page |
Restore a page to a previous version. |
Comment Mutations:
| Tool | Description |
|---|---|
wikijs_create_comment |
Create a comment on a page. |
wikijs_update_comment |
Update an existing comment by ID. |
wikijs_delete_comment |
Delete a comment by ID. |
Tag Mutations:
| Tool | Description |
|---|---|
wikijs_update_tag |
Update a tag's slug and title. |
wikijs_delete_tag |
Delete a tag from all pages. |
Mutation Safety
- When
WIKI_MUTATION_CONFIRM_TOKENis set, mutation tools require a matchingconfirmargument. - When
WIKI_MUTATION_DRY_RUN=true, write tools return a preview and do not mutate Wiki.js. - If
WIKI_ALLOWED_MUTATION_PATH_PREFIXESis set, page and comment-create mutations are limited to those path prefixes. - All mutation attempts write a structured audit line to stderr.
MCP Resources
| Resource URI | Description |
|---|---|
wikijs://markdown-guide |
Wiki.js markdown syntax guide (CommonMark/GFM + Wiki.js-specific extensions) intended for page authoring and updates. |
wikijs://mermaid-guide |
Mermaid 8.8.2 diagram syntax guide for Wiki.js (9 supported diagram types, unsupported feature warnings, version restrictions). |
wikijs://api-permissions-guide |
Wiki.js API permission model, error codes, and API key configuration guide for self-diagnosing permission errors. |
Permission Notes (Wiki.js)
Wiki.js permission behavior can be surprising for API keys. In particular:
- Some operations may require
manage:pages/delete:pagesrules at page-rule level. - Reading
contentmay requireread:sourcedepending on schema/field-level checks. - Comment operations require
read:comments,write:comments, ormanage:comments. - System info and navigation require admin-level API key permissions.
Common error codes:
| Code | Meaning |
|---|---|
| 6013 | PageViewForbidden — check group permissions + page rules for read:pages/read:source |
| 6003 | Page does not exist |
| 8002 | CommentPostForbidden |
| 8003 | CommentNotFound |
| 8004 | CommentViewForbidden |
| 8005 | CommentManageForbidden |
For more details, read the wikijs://api-permissions-guide resource.
Suggested Minimum API Key Permissions
For read-heavy KB use:
read:pages,read:sourceread:comments(for comment browsing)- Page rules allowing those permissions for intended paths/locales
For write workflows:
write:pages(create and update)manage:pagesordelete:pages(for delete/move operations)write:comments,manage:comments(for comment mutations)manage:system(for tag management)
Security Guidance
- Keep API token server-side only.
- Start with read-only permissions.
- Keep
WIKI_MUTATIONS_ENABLED=falseunless updates are needed. - Optional hardening: set a strong random
WIKI_MUTATION_CONFIRM_TOKENand pass matchingconfirmfor write calls. - Keep
WIKI_MUTATION_DRY_RUN=trueuntil you are ready for real writes. - Use
WIKI_ALLOWED_MUTATION_PATH_PREFIXESto constrain write scope. wikijs_get_system_infofilters sensitive infrastructure fields (dbHost, configFile, etc.) by default.scriptJs/scriptCssfields in page create/update are length-limited (10,000 chars) and include browser execution warnings.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.