CityJSON Specification MCP Server
OfficialClick on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@CityJSON Specification MCP ServerGet the outline of the CityJSON specification"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
CityJSON Specification MCP Server
An MCP (Model Context Protocol) server that provides AI assistants with structured access to the CityJSON specification. Instead of feeding entire specifications to LLMs, this server enables AI to fetch specific chapters on demand.
📺 Demo
https://github.com/user-attachments/assets/91f0bd61-a313-441c-8def-4e07b8d125be
🚀 Quick Start
Remote Server (Recommended)
Connect directly to the hosted server - no installation required:
https://your-cloud-run-url.run.app/mcpAlternatively, use the community-hosted instance (subject to availability and resource constraints):
https://cj-mcp-264879243442.europe-west4.run.app/mcpLocal Installation
Run locally using npx:
npx @cityjson/cj-mcp@latestOr install globally:
npm install -g @cityjson/cj-mcp@latest
cityjson-spec-mcp🛠️ Installation
Add to ~/.cursor/mcp.json:
{
"mcpServers": {
"cityjson-spec": {
"command": "npx",
"args": ["-y", "@cityjson/cj-mcp@latest"]
}
}
}Add to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):
{
"mcpServers": {
"cityjson-spec": {
"command": "npx",
"args": ["-y", "@cityjson/cj-mcp@latest"]
}
}
}Add to your VS Code settings:
{
"mcp": {
"servers": {
"cityjson-spec": {
"type": "stdio",
"command": "npx",
"args": ["-y", "@cityjson/cj-mcp@latest"]
}
}
}
}Add to your Windsurf MCP config:
{
"mcpServers": {
"cityjson-spec": {
"command": "npx",
"args": ["-y", "@cityjson/cj-mcp@latest"]
}
}
}🔨 Available Tools
cityjson_read_spec_outline
Returns the specification outline with all chapters and sections.
Parameters:
include_sections(boolean, optional): Include section headings within each chapter. Default:true
Example Response:
{
"version": "2.0.1",
"total_chapters": 12,
"chapters": [
{
"id": "introduction",
"title": "Introduction",
"order": 1,
"sections": ["overview", "design-goals", "file-extension"]
}
]
}cityjson_read_spec_chapter
Returns the full Markdown content for a specific chapter.
Parameters:
chapter(string, required): Chapter identifier (e.g.,"metadata","city-objects")
Example:
{
"chapter": "metadata"
}💻 Development
# Clone with submodules
git clone --recurse-submodules https://github.com/cityjson/cityjson-spec-mcp.git
cd cityjson-spec-mcp
# Install dependencies
pnpm install
# Build all packages
pnpm build
# Convert specification (requires uv/bikeshed)
pnpm convert-spec
# Start MCP server (stdio mode)
pnpm start:stdio
# Start MCP server (HTTP mode)
pnpm start:http
# Lint and format
pnpm lint
pnpm lint:fix📦 Project Structure
cityjson-spec-mcp/
├── packages/
│ ├── spec-converter/ # Bikeshed → Markdown converter
│ └── mcp-server/ # MCP server implementation
├── specs/ # Generated specification files
│ ├── index.json # Chapter metadata index
│ └── chapters/ # Individual chapter Markdown files
├── vendor/
│ └── cityjson-specs/ # Git submodule (CityJSON spec repo)
└── Dockerfile # Container for Cloud Run deployment📄 License
MIT
🔗 Resources
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/cityjson/cj-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server