Skip to main content

Community-contributable integrations (tools) for ModuleX

Project description

modulex-integrations

CI License: MIT PyPI

Community-contributable integrations (tools) for the ModuleX runtime.

Why this repo exists

modulex is a FastAPI/Python backend that, until now, bundled 45 LangChain tool integrations inline. We are extracting those 45 tools into this standalone, publicly pip-installable package so that:

  • adding a new tool is a single-repo PR, not a multi-file edit across the modulex monorepo,
  • integration code is publicly inspectable,
  • community contributions flow through the standard GitHub PR model.

LLM providers and knowledge providers stay in modulex. Only the tool integrations migrate here.

Status

Phase 1 — early development. The schema contract and packaging are in place; integrations themselves will be migrated from the modulex monorepo one at a time, starting with a github POC and continuing via a scripted bulk migration. See CHANGELOG.md for progress and CONTRIBUTING.md for layout rules.

What is this?

Each integration in this package exposes one or more LangChain @tool functions to the ModuleX runtime, together with credential metadata (auth schemas, env vars, test endpoints). The runtime discovers integrations via the Python modulex.tools entry-point group and loads them at startup.

Installation

pip install modulex-integrations

With every integration's optional dependencies:

pip install "modulex-integrations[all]"

Or only the integrations you need (extras are populated as integrations are migrated):

pip install "modulex-integrations[github,slack]"

Per-integration layout

Every integration ships in the same shape:

src/modulex_integrations/tools/<name>/
├── __init__.py        # re-exports manifest + TOOLS
├── manifest.py        # IntegrationManifest instance
├── tools.py           # LangChain @tool functions
├── outputs.py         # pydantic response models (UI/docs derive JSONSchema)
├── dependencies.toml  # per-integration runtime deps
├── README.md          # 5-section strict template (see CONTRIBUTING.md)
└── tests/
    └── test_<name>.py

The contract is enforced by pydantic types in src/modulex_integrations/schema.py with extra="forbid" everywhere — a typo in a manifest fails at import time, not at runtime.

Development

git clone https://github.com/ModuleXAI/modulex-integrations.git
cd modulex-integrations
pip install -e ".[dev]"
pytest
ruff check src tests
mypy src/modulex_integrations

Roadmap

  • Phase 1 — bootstrap (this commit). Schema, packaging, CI, community meta files, cross-repo brief workflow.
  • Phase 2 — github POC migration. One integration end-to-end: manifest, tools, outputs, tests, entry point, real httpx.MockTransport coverage of at least one action.
  • Phase 3 — scripted bulk migration. The remaining 44 integrations migrated by a one-shot script, then reviewed individually.

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

modulex_integrations-0.1.0a8.tar.gz (227.0 kB view details)

Uploaded Source

Built Distribution

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

modulex_integrations-0.1.0a8-py3-none-any.whl (318.6 kB view details)

Uploaded Python 3

File details

Details for the file modulex_integrations-0.1.0a8.tar.gz.

File metadata

  • Download URL: modulex_integrations-0.1.0a8.tar.gz
  • Upload date:
  • Size: 227.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for modulex_integrations-0.1.0a8.tar.gz
Algorithm Hash digest
SHA256 bd514cdf6cd41b9f3573e0d98d7dee9d16ab4af362e0de3174156cbb5b9d7237
MD5 d3b4bffb0ccb7bc324e35df2e1575b8f
BLAKE2b-256 c820dc33c7e2aeb4c9f01f53825278d04dedd053c14e2c95bc242f720d903697

See more details on using hashes here.

Provenance

The following attestation bundles were made for modulex_integrations-0.1.0a8.tar.gz:

Publisher: release.yml on ModuleXAI/modulex-integrations

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

File details

Details for the file modulex_integrations-0.1.0a8-py3-none-any.whl.

File metadata

File hashes

Hashes for modulex_integrations-0.1.0a8-py3-none-any.whl
Algorithm Hash digest
SHA256 24bb3c583caa9941e28c980d0af1852a330be2ab31987d417f4d6bec41da24a5
MD5 fc75a930cf1dfe0195a66a81e6f72708
BLAKE2b-256 74ef586867e8300067326d1e7c2f0637177119d12833bf6f684fb9e0d3f03ac3

See more details on using hashes here.

Provenance

The following attestation bundles were made for modulex_integrations-0.1.0a8-py3-none-any.whl:

Publisher: release.yml on ModuleXAI/modulex-integrations

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