Skald MCP Server
Chat with your Skald knowledge base, add and update new knowledge, and search through memos.
README
Skald MCP Server ðŸ§
Chat with your Skald knowledge base, add and update new knowledge, and search through memos.
Features
The Skald MCP server provides seven powerful tools:
1. skald-chat
Ask Skald questions about your knowledge base in natural language with optional filters to narrow search context.
2. skald-search
Search through your memos using multiple methods with optional filters:
- Semantic search (
chunk_vector_search) - Find relevant content by meaning - Title contains (
title_contains) - Case-insensitive substring matching - Title starts with (
title_startswith) - Case-insensitive prefix matching
3. skald-create-memo
Create new memos that are automatically processed, summarized, tagged, chunked, and indexed for search.
4. skald-get-memo
Retrieve a memo by UUID or client reference ID with full content, summary, tags, and chunks.
5. skald-update-memo
Update an existing memo by UUID or client reference ID. If content is updated, the memo will be reprocessed.
6. skald-delete-memo
Permanently delete a memo by UUID or client reference ID along with all associated data.
7. skald-generate
Generate documents based on prompts and retrieved context from the knowledge base with optional style/format rules and filters.
Setup
Prerequisites
- A Skald account with an API key. Get yours at platform.useskald.com
- Node.js 18.0.0 or higher
Installation
- Clone this repository:
git clone https://github.com/skaldlabs/skald-mcp
cd skald-mcp
- Install dependencies:
npm install
- Build the project:
npm run build
Configuration
Cursor
-
Open Cursor Settings (
cmd+shift+pon macOS orctrl+shift+pon Windows → "Cursor Settings") -
Select "MCP" from the left sidebar and click "Add new global MCP server"
-
Add the following configuration:
{
"mcpServers": {
"skald": {
"type": "command",
"command": "node ABSOLUTE_PATH_TO_PROJECT/build/index.js --key=YOUR_SKALD_API_KEY"
}
}
}
Replace:
ABSOLUTE_PATH_TO_PROJECTwith the full path to yourskald-mcpdirectoryYOUR_SKALD_API_KEYwith your Skald API key
Tip: Right-click on /build/index.js in Cursor and select "Copy Path" to get the absolute path.
Command-line arguments:
--key: Your Skald API key (required if not using environment variable)
Claude Desktop
-
Open Claude Desktop settings and navigate to the "Developer" tab
-
Click "Edit Config"
-
Add the following configuration:
{
"mcpServers": {
"skald": {
"command": "node",
"args": [
"ABSOLUTE_PATH_TO_PROJECT/build/index.js"
],
"env": {
"SKALD_API_KEY": "YOUR_SKALD_API_KEY"
}
}
}
}
Replace:
ABSOLUTE_PATH_TO_PROJECTwith the full path to yourskald-mcpdirectoryYOUR_SKALD_API_KEYwith your Skald API key
Environment variables:
SKALD_API_KEY: Your Skald API key (required)
- Restart Claude Desktop
Usage Examples
Chat with your knowledge base
Ask Cursor/Claude: "Check Skald for what are the instructions for running our Django server locally."
The assistant will query your Skald knowledge base and return an answer.
Search for memos
Ask Cursor/Claude: "Search Skald for the docs about our product vision"
The assistant will use the skald-search tool with semantic search to find relevant memos and display:
- Title
- UUID
- Summary
- Content snippet
- Relevance score (for semantic search)
If you had asked for "memos with Product Vision in the title", the agent would pick another search method such as title_contains.
Create a new memo
Ask Cursor/Claude: "Generate an API reference for my endpoints and upload it to Skald"
The assistant will create a new memo in your Skald knowledge base, which will be automatically processed and made searchable.
Tool Parameters
skald-chat
| Parameter | Type | Required | Description |
|---|---|---|---|
query |
string | Yes | The question to ask your knowledge base |
project_id |
string | No | Project UUID (required when using Token Authentication) |
filters |
Filter[] | No | Optional filters to narrow the search context |
skald-search
| Parameter | Type | Required | Description |
|---|---|---|---|
query |
string | Yes | The search query |
search_method |
enum | Yes | One of: chunk_vector_search, title_contains, title_startswith |
limit |
number | No | Maximum results to return (1-50, default 10) |
filters |
Filter[] | No | Optional filters to narrow results |
skald-create-memo
| Parameter | Type | Required | Description |
|---|---|---|---|
title |
string | Yes | The title of the memo (max 255 characters) |
content |
string | Yes | The full content of the memo |
project_id |
string | No | Project UUID (required when using Token Authentication) |
metadata |
object | No | Custom JSON metadata |
reference_id |
string | No | External reference ID to match with your documents |
tags |
string[] | No | Tags for categorization |
source |
string | No | Source of the content (useful for integrations) |
skald-get-memo
| Parameter | Type | Required | Description |
|---|---|---|---|
memo_id |
string | Yes | The memo UUID or client reference ID |
id_type |
enum | No | Type of identifier: memo_uuid (default) or reference_id |
skald-update-memo
| Parameter | Type | Required | Description |
|---|---|---|---|
memo_id |
string | Yes | The memo UUID or client reference ID |
id_type |
enum | No | Type of identifier: memo_uuid (default) or reference_id |
title |
string | No | New title for the memo |
content |
string | No | New content for the memo |
metadata |
object | No | New metadata |
client_reference_id |
string | No | New client reference ID |
source |
string | No | New source |
expiration_date |
string | No | New expiration date |
skald-delete-memo
| Parameter | Type | Required | Description |
|---|---|---|---|
memo_id |
string | Yes | The memo UUID or client reference ID |
id_type |
enum | No | Type of identifier: memo_uuid (default) or reference_id |
skald-generate
| Parameter | Type | Required | Description |
|---|---|---|---|
prompt |
string | Yes | The prompt for document generation |
rules |
string | No | Optional style/format rules |
filters |
Filter[] | No | Optional filters to control which memos are used as context |
Filter Object
Filters are used in skald-chat, skald-search, and skald-generate to narrow results:
| Field | Type | Required | Description |
|---|---|---|---|
field |
string | Yes | The field to filter on |
operator |
enum | Yes | One of: eq, neq, contains, startswith, endswith, in, not_in |
value |
string or string[] | Yes | The value to filter by |
filter_type |
enum | Yes | native_field (e.g., source, tags) or custom_metadata |
Example filter:
{
"field": "source",
"operator": "eq",
"value": "notion",
"filter_type": "native_field"
}
Development
Build
npm run build
Lint
npm run lint
Fix linting issues
npm run lint:fix
Troubleshooting
API Key Issues
If you get an error about a missing API key:
- For Cursor: Ensure the
--keyargument is set in your config - For Claude Desktop: Ensure
SKALD_API_KEYis set in the env section
Module Not Found
If you see "Cannot find module '@skald-labs/skald-node'":
npm install
npm run build
Connection Issues
Check the debug logs:
- Cursor: Check the MCP server logs in Cursor settings
- Claude Desktop: Check the logs in Claude Desktop developer settings
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.
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.
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.
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.