imo-rules-mcp

imo-rules-mcp

Provides offline semantic search and reading of IMO maritime rules (SOLAS, MARPOL, STCW, etc.) to AI clients via MCP.

Category
Visit Server

README

imo-rules-mcp

An MCP server that exposes a local corpus of IMO maritime rules & regulations (SOLAS, MARPOL, STCW, the codes, …) to AI clients (Claude Code, Claude Desktop, Cursor, any MCP host) for offline semantic search and reading. No crawler, no network — it serves a local corpus you provide.

⚠️ Bring your own corpus (important)

This repository contains only the server code. It does not include any regulation text. The IMO rules & regulations corpus is copyrighted by its rights holders and is licensed to you separately — do not commit it to a public repository or redistribute it. The corpus/ directory is gitignored for this reason. If you choose to bundle a corpus into a repo for convenience, keep that repository private.

What you provide

A corpus directory (default ./corpus/) containing:

corpus/
  imo-corpus.sqlite     # the SQLite corpus (documents, nodes, citations)
  toc.json              # the final navigation tree (instruments → chapters → regulations)
  rag/
    config.json
    meta.json
    vectors.f32         # one embedding per page
    models/…            # the local embedding model (q8 ONNX)

This layout is produced by the companion KRcrawl exporter (export:full-help + rag:index). Import it with:

npm install
node scripts/import-corpus.mjs /path/to/KRcrawl     # copies DB + toc.json + rag/ into ./corpus

Or skip the copy and point the server at an existing build with env vars (below).

Tools

Tool What it does
imo_semantic_search Meaning-based search → ranked regulations w/ instrument breadcrumb, snippet, docKey.
imo_keyword_search Substring search over titles (optionally body text).
imo_get_document Full normalized text of one regulation by docKey, + breadcrumb + citations.
imo_list_instruments Top-level instruments (SOLAS, MARPOL, STCW, the codes, …).
imo_browse Navigate the instrument → chapter → regulation tree.
imo_get_citations Outbound cross-references from one document.
imo_stats Corpus overview.

imo_semantic_search lazily loads the bundled q8 embedding model on first call (a few seconds); other tools are instant. Read-only, offline.

Use it

Claude Code

A project-scoped .mcp.json is included. Open this directory in Claude Code, approve the imo-rules server when prompted, and the imo_* tools become available. (Restart/reconnect once — a newly-added MCP server is not live in a running session.)

Claude Desktop / other MCP hosts

Add to the host's MCP config, pointing cwd at this repo (so ./corpus resolves):

{
  "mcpServers": {
    "imo-rules": {
      "command": "npx",
      "args": ["tsx", "src/server.ts"],
      "cwd": "/path/to/imo-rules-mcp"
    }
  }
}

Smoke-test standalone: npm start (speaks MCP over stdio; Ctrl-C to stop).

Configuration (env vars)

Var Default Meaning
IMO_DB corpus/imo-corpus.sqlite SQLite corpus path
IMO_RAG corpus/rag semantic-search index dir
IMO_TOC <IMO_RAG>/../toc.json navigation tree (override if it lives elsewhere)
IMO_ROOT_KEY 0000.00e0 top-level tree key for imo_list_instruments

Tip: to run against an existing KRcrawl build in place (no copy), set IMO_DB=<KRcrawl>/data/krcon.sqlite, IMO_RAG=<KRcrawl>/dist/help/full-clone/assets/rag, IMO_TOC=<KRcrawl>/dist/help/full-clone/toc.json.

License

Server code: MIT (see LICENSE). The license covers the code only — not any corpus data you supply.

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
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
Qdrant Server

Qdrant Server

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

Official
Featured