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.1.tar.gz (38.5 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.1-py3-none-any.whl (36.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: simple_module_core-0.0.1.tar.gz
  • Upload date:
  • Size: 38.5 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.1.tar.gz
Algorithm Hash digest
SHA256 114b4299bdadca724ac3ed31e336ee1153020365409e836f788019cef98b6f05
MD5 b57f0865d88af0bfe863db11f0d40db8
BLAKE2b-256 1be54573aa8199c7b8641d00d36ec50a72d4239bfea4e0fdc696556df5bb8f0f

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_module_core-0.0.1.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.1-py3-none-any.whl.

File metadata

File hashes

Hashes for simple_module_core-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 830b23a1c5fc32ba1686798a1802220c23c202ea6ccab3d03815d4b2361aa282
MD5 c2bf87479885fc4cf3bc578b4baf9bb7
BLAKE2b-256 6103d4d3bd2bd4f1cc9ce19b9fe4b5a0fd8620fd67b30db3630d8f56486b3b52

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_module_core-0.0.1-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