okf-tools

okf-tools

Enables local semantic search and management of OKF knowledge bundles via MCP tools, with hybrid BM25 and vector search.

Category
Visit Server

README

okf-mcp

Local semantic search over OKF knowledge bundles. No API keys, no cloud services.

Why it exists: Engineers waste hours rediscovering knowledge that already exists — scattered across wikis, Slack, git history, and colleagues' heads. OKF defines a vendor-neutral format (published by Google Cloud Platform) for persisting that knowledge as markdown; okf-mcp makes it queryable and useful in practice. OKF defines the format; okf-mcp provides the tooling layer.

Write markdown files with YAML frontmatter → okf-mcp makes them queryable via hybrid search (BM25 keyword + vector cosine similarity).

Quick Start

# Install (requires Python 3.10+)
git clone https://github.com/hdean-ssp/okf-mcp.git
cd okf-mcp
source activate.sh

# Create a bundle
mkdir ~/my-knowledge && cd ~/my-knowledge
git init && okf init

# Add a concept
okf commit --check-duplicates --json '{
  "title": "Retry Pattern",
  "type": "Pattern",
  "content": "Use exponential backoff with jitter for transient failures.",
  "tags": ["reliability", "networking"]
}'

# Build search index (first run downloads ~30MB embedding model)
# Note: first run takes ~30 seconds to download the model. Subsequent runs are instant.
okf reindex

# Search
okf fetch "how to handle network failures"

What Next?

After completing the Quick Start above:

  • okf fetch "your question" — search your bundle with natural language
  • okf list — browse all concepts
  • okf show <concept-id> — view full concept content
  • okf stats — check bundle health
  • See Use Cases & Examples for real-world workflows
  • See Getting Started for the full guide

Commands

Command Purpose
okf init Initialise a new bundle
okf commit Create a concept
okf fetch <query> Hybrid search (BM25 + semantic)
okf show <id> Display a concept
okf list Browse concepts (filterable)
okf update <id> Modify a concept
okf move <id> <new-id> Move or rename a concept
okf delete <id> Remove a concept
okf reindex Rebuild the vector index
okf stats Bundle statistics

All commands support --format json|text|brief. Output is JSON when piped (agent-friendly), text when interactive.

How It Works

  • Markdown files are the source of truth — the vector index is a derived sidecar, gitignored and rebuildable
  • Hybrid search — combines BM25 keyword matching with vector semantic similarity. No external services.
  • Local embeddings — fastembed + BAAI/bge-small-en-v1.5 (384 dimensions), no API keys
  • Incremental indexing — only re-embeds changed files (mtime comparison)

MCP Server

okf-mcp includes an MCP (Model Context Protocol) server, letting any MCP-compatible client (Kiro, Claude Desktop, etc.) use your knowledge bundle directly.

Quick Start — MCP Server

# Start the server (from within your bundle directory)
okf-mcp

# Or point to a specific bundle
okf-mcp --bundle-path ~/my-knowledge

The server communicates over stdio (JSON-RPC). You don't run it manually for normal use — instead, configure your MCP client to launch it.

Client Configuration

Team/Shared Deployment (recommended — see Team Setup Guide):

Create ~/.kiro/settings/mcp.json on the server:

{
  "mcpServers": {
    "okf-mcp": {
      "command": "/path/to/okf-mcp/.venv/bin/okf-mcp",
      "args": [
        "--bundle-path",
        "/path/to/your/team-bundle"
      ],
      "autoApprove": [
        "commit_concept", "delete_concept", "fetch_concepts",
        "get_stats", "init_bundle", "list_concepts",
        "move_concept", "reindex", "show_concept", "update_concept"
      ]
    }
  }
}

Kiro via Remote-SSH (generic setup — Kiro connects to server, MCP runs locally on server):

{
  "mcpServers": {
    "okf-mcp": {
      "command": "/path/to/okf-mcp/.venv/bin/okf-mcp",
      "args": ["--bundle-path", "/path/to/your/bundle"],
      "autoApprove": [
        "fetch_concepts", "list_concepts", "show_concept",
        "get_stats", "reindex"
      ]
    }
  }
}

Local setup (Kiro and bundle on same machine):

{
  "mcpServers": {
    "okf-mcp": {
      "command": "okf-mcp",
      "args": ["--bundle-path", "/path/to/your/bundle"],
      "autoApprove": [
        "fetch_concepts", "list_concepts", "show_concept",
        "get_stats", "reindex"
      ]
    }
  }
}

See MCP Setup Guide for individual installation or Team Setup Guide for onboarding to the shared deployment.

Available Tools

Tool Description
init_bundle Create a new bundle at a given path
commit_concept Add a new concept (title, type, content, tags)
update_concept Modify fields on an existing concept
move_concept Move or rename a concept
delete_concept Remove a concept
fetch_concepts Semantic/hybrid search with natural language
list_concepts Browse concepts with filters (type, tags, date, path)
show_concept Get full content of a concept
reindex Rebuild the vector search index
get_stats Bundle health statistics

Notes

  • The server starts without a bundle configured — use init_bundle to create one, or pass --bundle-path
  • All tools except init_bundle require a configured bundle
  • Errors are returned as structured MCP tool errors (no stack traces exposed)
  • All logging goes to stderr (stdout is the JSON-RPC channel)

Agent Integration

The MCP server handles agent integration directly — no hooks or CLI wrappers needed.

  • agent/AGENT.md — agent usage guide (when to use, MCP tools reference, workflow pattern)

Agents access the knowledge bundle through MCP tools (fetch_concepts, commit_concept, etc.) rather than shelling out to CLI commands.

Documentation

Development

git clone https://github.com/hdean-ssp/okf-mcp.git
cd okf-mcp
source activate.sh
pip install -e ".[dev]"
pytest

Dev dependencies include pytest, hypothesis (property-based testing), and pytest-asyncio.

Branches

  • main — MCP server and CLI. Focused on the essential loop: init → commit → fetch → reindex, exposed via both CLI and MCP.

License

Apache 2.0

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

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.

Official
Featured