Skip to main content

BAUER GROUP MCP framework — config-driven, pluggable REST-API MCP servers on FastMCP

Project description

BAUER GROUP - BG-MCPCore

PyPI Version Python Support License: MIT 🧪 Tests

BAUER GROUP MCP framework — config-driven, pluggable REST-API MCP servers on FastMCP.

bg-mcpcore is the shared foundation for BAUER GROUP's fleet of Model Context Protocol servers that bridge REST APIs (Zammad, Shlink, and more). It turns "stand up a secure, OAuth-gated MCP server for an API" from a multi-day clone-and-edit job into a short declarative profile.

Repository Information:

  • Version: v1.4.0 (2026-06-01)
  • Repository: bauer-group/LIB-BG-MCPCore
  • Branch: main
  • Architecture: Config-driven, pluggable, secure-by-default

The idea: config for the standard, code for the complex

A server is described by a declarative JSON profile. Standard behaviour — identity, backend connection, inbound/outbound auth, rate limiting, observability, health/branding routes, and OpenAPI-derived tools — needs no Python. The genuinely complex parts (hand-written tools, per-user on-behalf-of token flows) drop down to Python escape hatches the profile points at.

// profiles/mautic.json — a whole server, no Python
{
  "id": "mautic",
  "display_name": "BAUER GROUP Mautic",
  "backend": { "base_url": "${env:MAUTIC_URL}", "api_base_path": "/api" },
  "auth": {
    "inbound":  { "mode": "oidc" },
    "outbound": { "type": "bearer_env", "value_from_env": "MAUTIC_TOKEN" }
  },
  "tools": { "source": "openapi", "spec": { "source": "${env:MAUTIC_OPENAPI_URL}" } }
}
# src/main.py — the entire entrypoint
from bg_mcpcore import load_profile, make_cli

app = make_cli(load_profile("profiles/mautic.json"))
if __name__ == "__main__":
    app()

Install

Requires Python 3.12, 3.13, or 3.14.

From PyPI

pip install bg-mcpcore

Directly from GitHub

# Latest from main
pip install git+https://github.com/bauer-group/LIB-BG-MCPCore.git@main

# A specific released version/tag
pip install git+https://github.com/bauer-group/LIB-BG-MCPCore.git@v1.4.0

# With extras (any install method)
pip install "bg-mcpcore[openapi] @ git+https://github.com/bauer-group/LIB-BG-MCPCore.git@main"

Optional extras

pip install "bg-mcpcore[openapi]"                               # + OpenAPI-derived tools
pip install "bg-mcpcore[openapi,redis,tasks,oauth-providers]"   # full Shlink-shaped server
Extra Adds
openapi tools.source: "openapi" — generate the tool surface from an OpenAPI spec
redis Redis-backed encrypted OAuth-state store (multi-replica deployments)
oauth-providers Entra / Google + the spec-driven IdP modes (Auth0, Keycloak, GitHub, AWS Cognito, WorkOS, …)
tasks long-running task execution (bulk exports)
testkit reusable pytest fixtures + stubs (pytest11 plugin)

Architecture

  • Pluggable via Python entry points — new auth_providers, tool_sources, auth_resolvers are pip-installable plugins, never core edits.
  • Central tool registry — reusable tools (bg.health, …) referenced by name from any profile (tools.source: "registry").
  • Fail-closed by designAUTH_MODE=none forbidden in production; the JWT signing key mandatory for any active mode; invariants live in core.

See the documentation for the profile schema reference, plugin authoring guide, and security model.

License

MIT © BAUER GROUP

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

bg_mcpcore-1.5.0.tar.gz (142.2 kB view details)

Uploaded Source

Built Distribution

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

bg_mcpcore-1.5.0-py3-none-any.whl (87.4 kB view details)

Uploaded Python 3

File details

Details for the file bg_mcpcore-1.5.0.tar.gz.

File metadata

  • Download URL: bg_mcpcore-1.5.0.tar.gz
  • Upload date:
  • Size: 142.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for bg_mcpcore-1.5.0.tar.gz
Algorithm Hash digest
SHA256 5c7b3756f7ad476a6101dda7b4e9e905bceddc55476fcb099edfb94e7fa927e5
MD5 eb60d557ecf7438b74a11001306a14ca
BLAKE2b-256 fc037b061b1302c2b43b9e500b7426d8c0e13aebd5fee2827787b6a4fbdd6e65

See more details on using hashes here.

File details

Details for the file bg_mcpcore-1.5.0-py3-none-any.whl.

File metadata

  • Download URL: bg_mcpcore-1.5.0-py3-none-any.whl
  • Upload date:
  • Size: 87.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for bg_mcpcore-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 02cf6d32ac4f4e320f97fa37aedfe42c7d53ffb2ccef3423a7988676673d8c94
MD5 55057f91979f187d145458a0104d6db5
BLAKE2b-256 946f164d5fed9418537b0466e7827cdbd3d3a44ac6ed2a9cbcecc2c2ef52fd94

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