darktable-mcp

darktable-mcp

Enables Claude and other AI assistants to control darktable for photo management and editing through its Lua API.

Category
Visit Server

README

Darktable MCP Server

A Model Context Protocol (MCP) server that exposes a small set of darktable operations to MCP clients (e.g. Claude Desktop, Claude Code). The AI lives in the client; this server drives darktable.

Status

Production ready for headless operations! All core library tools are now implemented using darktable's headless Lua API.

Implemented tools:

  • view_photos - Browse your darktable library with filtering and rating options (headless)
  • rate_photos - Apply star ratings to photos in your library (headless)
  • import_batch - Import photos from directories (headless)
  • adjust_exposure - Adjust exposure with live preview (opens darktable GUI)
  • export_images - Export photos to JPEG/PNG/TIFF via darktable-cli

Not yet implemented:

  • apply_preset - Apply editing presets to photos (planned for next release)

The headless integration uses darktable's native Lua API via require("darktable") to provide fast, invisible library operations while respecting all design principles.

Design rules (no compromise)

  1. Use the provided darktable APIs only. darktable-cli for export; the official Lua API for everything else. Do not read or write library.db directly under any circumstances.
  2. Tools that return data to the AI must be headless. Spawning the darktable GUI to answer a query is unacceptable.
  3. GUI is only acceptable when the tool's purpose is to show the human user something in the darktable editor. No such tool exists yet. When one is added, it is the only thing that may launch the GUI.

Why some tools are parked

darktable-cli deliberately does not load the user's library, so it cannot browse it. darktable --lua brings up the full GUI. That means there is no headless, official-API path today for library reads or writes. The honest answer is to not ship those tools yet.

The planned unblocker is a long-running darktable instance running a Lua plugin that exposes a small RPC (e.g. unix socket); the MCP server talks to that plugin. That keeps every rule above intact — official API, headless after the user already has darktable open, no DB poking.

Installation

pip install darktable-mcp

You also need darktable (with darktable-cli) installed and available on your PATH.

Quick test: After installation, try:

# In Claude Desktop, you can now ask:
# "Show me my recent photos" (uses view_photos)
# "Rate these photos 4 stars" (uses rate_photos) 
# "Import photos from ~/Pictures/vacation" (uses import_batch)

Note: First run will auto-detect your darktable library location. Make sure you've opened darktable and imported some photos before using the MCP server.

Configuration

Add to your Claude Desktop config:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json
  • Linux: ~/.config/Claude/claude_desktop_config.json
{
  "mcpServers": {
    "darktable": {
      "command": "darktable-mcp"
    }
  }
}

Implemented tools

  • view_photos(filter?, rating_min?, limit?) — Browse photos in your darktable library. Filter by filename, minimum rating, or limit results.
  • rate_photos(photo_ids, rating) — Apply 1-5 star ratings to specific photos by ID.
  • import_batch(source_path, recursive?) — Import photos from directories into your darktable library.
  • adjust_exposure(photo_ids, exposure_ev) — Adjust exposure settings for photos. Opens darktable GUI to show preview.
  • export_images(photo_ids, output_path, format, quality?) — Export photos to JPEG/PNG/TIFF via darktable-cli.

Stubbed tools (registered, not implemented)

  • apply_preset(photo_ids, preset_name) — Apply editing presets to photos. Planned for next release.

Requirements

  • Python 3.8+
  • darktable 4.0+ (with darktable-cli on PATH)
  • An MCP-compatible client (Claude Desktop, Claude Code, etc.)

Troubleshooting

"darktable setup error" — Ensure darktable is installed and you've opened it at least once to create the library database.

"Failed to parse photo data" — Your darktable library may be corrupted or in an unexpected format. Try opening darktable directly to verify it works.

"Library not found" — The auto-detector couldn't find your darktable library. Common locations:

  • Linux: ~/.config/darktable/library.db
  • macOS: ~/Library/Application Support/darktable/library.db
  • Windows: %APPDATA%\Local\darktable\library.db

If your library is in a custom location, please open an issue.

Tool timeouts — Some operations may take longer on large libraries. This is normal for the first run or after major library changes.

Contributing

Contributions welcome. The most useful starting point is the long-running Lua-plugin + IPC integration that unblocks every parked tool. Any change that reads or writes library.db directly will be rejected.

License

MIT — see LICENSE.

Keywords

darktable, MCP, model context protocol, photo editing, RAW processing, batch processing, photography workflow, Claude

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