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: 1.0.1 (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.0.1

# 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.1.0.tar.gz (68.6 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.1.0-py3-none-any.whl (70.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: bg_mcpcore-1.1.0.tar.gz
  • Upload date:
  • Size: 68.6 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.1.0.tar.gz
Algorithm Hash digest
SHA256 daff6f754725f840ed8cf485a974852af017083999775de7df86cc62a5e72275
MD5 00ae7f97d45b00c9a6fe12aa5b103c15
BLAKE2b-256 353c2d58730eac80d62132648e69d4568a612c7eec7a1aab4c2e36460059bf98

See more details on using hashes here.

File details

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

File metadata

  • Download URL: bg_mcpcore-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 70.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.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b43b0c5dfe33c4277735a92b9aecc25ff49fe81b5526542dad468dad429b172e
MD5 fad21b654076894de951a092fd5691ac
BLAKE2b-256 cebc94a8d4b2359d19147aba2f27e647aa775ef845edf1316379cebd6e95f1ef

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