Skip to main content

Shared infrastructure (typed exceptions, central config, structured logging + tracing) for MGF projects

Project description

mgf-common

PyPI version Python versions License: MIT Typed: PEP 561

The cornerstone library for the Magogi ecosystem. Typed exceptions + layered configuration + structured logging + OTel + crash reporting + vault + process management + FastAPI/Django/ alembic adapters — bundled into one PEP 561 typed package so every Magogi project (and any compatible consumer) inherits the same shape.

Status: pre-1.0 (current 0.24.0). API stable enough that three real consumers (VManager Qt desktop, inthewords Django, PlasmaMapper FastAPI) ship with it. Public names are experimental per AP-11; promoted to stable after one full MINOR cycle without a 🔴 Blocker filed against them.


Pick your starting point

The docs are organised by audience. Pick one:

If you are… Read
Evaluating mgf-common (right library for me?) docs/audience/shoppers.md
Building with it (already adopted) docs/audience/users.md
Contributing or designing alongside docs/audience/developers.md
A test/QA engineer docs/audience/qa.md
Cutting releases / running CI docs/audience/release.md
Doing a security review docs/audience/security.md
An AI agent (Claude or other) docs/audience/ai-agents.md

If you don't fit any of these neatly: docs/audience/README.md is the meta-routing index.

If you just want to try it: see docs/tutorial.md (zero → working app in ~30 minutes).


At a glance

import mgf.common as mc

with mc.bootstrap(app_name="myapp", app_version="1.0") as ctx:
    # identity + logging + OTel + excepthooks all wired transactionally
    do_work()
# Clean shutdown on context-exit; LIFO rollback on any startup failure.
from mgf.common.process import Service, AllOf, PortReady, LogLineReady

with Service(
    ["postgres", "-D", str(db_dir), "-p", str(port)],
    ready=AllOf([
        PortReady("127.0.0.1", port),
        LogLineReady(r"database system is ready"),
    ]),
    timeout_s=20.0,
) as svc:
    run_my_integration_tests(port=port)
# Service stopped + process group cascaded on context-exit.

More: docs/recipes/ (17 cookbook patterns) and PUBLIC_API.md (full surface).


Top-level files

File Purpose
STARTHERE.md Two-flow navigation hub (new project vs catching up an existing one)
FEEDBACK.md Living queue of consumer-filed feedback (the relay process driver)
CHANGELOG.md Per-release short-form (Keep-a-Changelog format)
PUBLIC_API.md Full public surface, table-form
PUBLIC_API.json Auto-generated machine-readable surface
SECURITY.md Vulnerability reporting policy (per SC-12)
CONTRIBUTING.md Dev setup + the four green gates + PR process

Consumers using it today

  • VManager — Qt desktop, libvirt VM toolkit (reference consumer; co-designed)
  • inthewords — Django web app (canonical web consumer)
  • PlasmaMapper — FastAPI scientific platform ("small consumer" scope discipline)

License

MIT. See LICENSE.

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

mgf_common-0.29.0.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

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

mgf_common-0.29.0-py3-none-any.whl (458.7 kB view details)

Uploaded Python 3

File details

Details for the file mgf_common-0.29.0.tar.gz.

File metadata

  • Download URL: mgf_common-0.29.0.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","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 mgf_common-0.29.0.tar.gz
Algorithm Hash digest
SHA256 02283b6e5831635a0ec392241db4d17e53b4497c371369332cec23769289e633
MD5 7018d83d596cce2b344cfe327af0e913
BLAKE2b-256 884e0a8743c4d6828dc27af240eca8ad07b6bac4ad07d606c474dfe120239fb3

See more details on using hashes here.

File details

Details for the file mgf_common-0.29.0-py3-none-any.whl.

File metadata

  • Download URL: mgf_common-0.29.0-py3-none-any.whl
  • Upload date:
  • Size: 458.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","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 mgf_common-0.29.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3904cb4c76ac21b2f75ae7c38eabacc96dc4f5cd7eea407e5aa8cb21e3dd8dbf
MD5 445d1f31de0f33e6d2baf05efe3d5338
BLAKE2b-256 67966a98d6f11e8b697fee78cba1de8fe5304272847c6386b90fa993da1557a5

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