Skip to main content

Rules server for agents with REST and MCP interfaces

Project description

Daimyo - Rules Server for Agents

Daimyo (大名) is an extensible Python server providing rules to AI agents through REST and MCP interfaces. Supports scope-based rules with inheritance, categories for filtering, and server federation for distributed rule management.

Features

  • Multiple Interfaces: REST API, MCP (Model Context Protocol), and CLI
  • Scope Inheritance: Single and multiple parent inheritance with priority-based conflict resolution
  • Rule Types: Commandments (MUST) and Suggestions (SHOULD)
  • Categories: Organize rules into hierarchical categories for selective retrieval
  • Server Federation: Distribute scopes across multiple servers with automatic merging
  • Multiple Formats: Output as YAML, JSON, or Markdown
  • Clean Architecture: Domain-driven design with clear separation of concerns
  • Templating System: Rules can use Jinja2 templates to be defined as generic rules that change their form depending on the context
  • Extensibility via Plugins: Plugins can extend the features of daimyo instances
  • Configurable Markdown Formatting: Prologues/epilogues, XML tag wrapping, and aggregated display modes

Installation

pip install daimyo

Or install from source:

git clone https://gitlab.com/Kencho1/daimyo.git
cd daimyo
pip install -e .

Quick Start

1. Set Up Your Rules

mkdir -p .daimyo
cp -r example-daimyo-rules .daimyo/rules

2. Start the Server

daimyo serve

3. Access the API

Visit http://localhost:8000/docs for interactive API documentation.

curl http://localhost:8000/api/v1/scopes/python-general/rules

Core Concepts

Rules are organized into scopes (e.g. company, team, project), each containing commandments (MUST) and suggestions (SHOULD). Scopes can inherit from parent scopes and organize rules into hierarchical categories for selective retrieval. Multiple servers can be federated to distribute scopes across deployments.

Documentation

Full documentation is available at https://daimyo.readthedocs.io/en/latest, including:

Development

Running Tests

pip install -e ".[test]"
pytest

Code Quality

mypy daimyo
ruff check daimyo
ruff format daimyo

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

daimyo-1.15.0.tar.gz (92.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

daimyo-1.15.0-py3-none-any.whl (82.3 kB view details)

Uploaded Python 3

File details

Details for the file daimyo-1.15.0.tar.gz.

File metadata

  • Download URL: daimyo-1.15.0.tar.gz
  • Upload date:
  • Size: 92.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for daimyo-1.15.0.tar.gz
Algorithm Hash digest
SHA256 5ef2d09b7ae886f16c9029bbfaae216114c7a2f28afe3e7699a92be5b9531bd2
MD5 0b5831023bcdd12e2f903a9b0be54de4
BLAKE2b-256 f1e0d1888975c14b752edf038b708ddd4a88a3ca7f3606fdbfcdc1a525e9566b

See more details on using hashes here.

File details

Details for the file daimyo-1.15.0-py3-none-any.whl.

File metadata

  • Download URL: daimyo-1.15.0-py3-none-any.whl
  • Upload date:
  • Size: 82.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for daimyo-1.15.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c6115b094972a617e07a7e30849dd007d764c581f93d8c2fc57de35467570d92
MD5 8313654a72a2f1529eb8187a70773bc5
BLAKE2b-256 a86e3a2a54b3a7bd55217b7cd3b2c9655b3092a5733a4140a61da2781b3fd799

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page