Skip to main content

Module-system primitives for the simple_module framework — ModuleBase, discovery, diagnostics, events

Project description

simple_module_core

Module-system primitives for the simple_module framework — a modular-monolith for Python/FastAPI where each feature is a plugin package discovered at boot.

This package defines ModuleBase, the ModuleMeta descriptor, the discover_modules() entry-point loader, topological dependency sorting, event bus primitives, and the diagnostic codes (SM001SM017) used by make doctor.

Install

pip install simple_module_core

You usually don't install this directly — it's pulled in by simple_module_hosting and every simple_module_* module.

What it provides

  • ModuleBase — the subclass every module extends to opt into lifecycle hooks.
  • ModuleMeta — required meta = ModuleMeta(name=..., depends_on=...) attribute on each module.
  • discover_modules() — loads all [project.entry-points.simple_module] modules, topologically sorts by depends_on.
  • Diagnostic registry — SM001 missing meta, SM003 orphan page, SM008 duplicate name, SM009 framework→plugin coupling violation, and ~ten others.
  • Tiny event-bus (pyee) for decoupled module-to-module communication.

Usage

# modules/orders/orders/module.py
from simple_module_core import ModuleBase, ModuleMeta


class OrdersModule(ModuleBase):
    meta = ModuleMeta(name="orders", depends_on=["users"])

    def register_routes(self, api_router, view_router):
        from .endpoints import api, views
        api_router.include_router(api.router)
        view_router.include_router(views.router)

And in pyproject.toml:

[project.entry-points.simple_module]
orders = "orders.module:OrdersModule"

The host's discover_modules() call picks this up automatically at boot.

Depends on

  • fastapi, pydantic, pydantic-settings, pyee, babel, packaging

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

simple_module_core-0.0.2.tar.gz (38.7 kB view details)

Uploaded Source

Built Distribution

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

simple_module_core-0.0.2-py3-none-any.whl (36.8 kB view details)

Uploaded Python 3

File details

Details for the file simple_module_core-0.0.2.tar.gz.

File metadata

  • Download URL: simple_module_core-0.0.2.tar.gz
  • Upload date:
  • Size: 38.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for simple_module_core-0.0.2.tar.gz
Algorithm Hash digest
SHA256 884f5793241e116fe88ee7f9adc92bfb11a3c003c03ec9f1ec2a27c3a3b173c7
MD5 59069df6f779a4947c5875c908b60031
BLAKE2b-256 93554e53f4038e7ca744514abc2004234dce7f86c85dab8125018461957bdb9f

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_module_core-0.0.2.tar.gz:

Publisher: release.yml on antosubash/simple_module_python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file simple_module_core-0.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for simple_module_core-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b663c9b3f42c7cd84d285962ccfb9904fba7ad071721b51ab62c053df1a8d330
MD5 396a525b0e95a06483cd52836de87dd2
BLAKE2b-256 802844c2b1d5658f0b45512fb2de5efb23d2735ff82fb26d08d3f2d6eb7e31ce

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_module_core-0.0.2-py3-none-any.whl:

Publisher: release.yml on antosubash/simple_module_python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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