MLD Plugin SDK - Build analysis plugins for the MLD platform
Project description
MLD SDK (Python)
SDK for building analysis plugins that integrate with the MLD platform.
Full Documentation: See the comprehensive docs for detailed API reference and guides.
Installation
# From PyPI (when published)
uv add mld-sdk
# From git
uv add git+https://github.com/EstrellaXD/mld#subdirectory=sdk
Quick Start
Create a plugin by implementing the AnalysisPlugin interface:
from mld_sdk import AnalysisPlugin, PluginMetadata, PluginCapabilities
from fastapi import APIRouter
router = APIRouter()
@router.get("/hello")
async def hello():
return {"message": "Hello from my plugin!"}
class MyPlugin(AnalysisPlugin):
@property
def metadata(self) -> PluginMetadata:
return PluginMetadata(
name="My Plugin",
version="1.0.0",
description="My analysis plugin",
analysis_type="metabolomics",
routes_prefix="/my-plugin",
capabilities=PluginCapabilities(
requires_auth=True,
requires_experiments=True,
),
)
def get_routers(self):
return [(router, "")]
async def initialize(self, context=None):
self._context = context
async def shutdown(self):
pass
Plugin Package Structure
mld-plugin-example/
├── pyproject.toml
├── README.md
└── src/mld_plugin_example/
├── __init__.py
└── plugin.py
pyproject.toml
[project]
name = "mld-plugin-example"
version = "1.0.0"
dependencies = ["mld-sdk>=1.0.0"]
[project.entry-points."mld.plugins"]
example = "mld_plugin_example.plugin:MyPlugin"
[build-system]
requires = ["hatchling"]
build-backend = "hatchling.build"
[tool.hatch.build.targets.wheel]
packages = ["src/mld_plugin_example"]
The entry point mld.plugins is how the platform discovers your plugin.
Platform Context
When running integrated with the platform, your plugin receives a PlatformContext that provides access to:
- Authentication dependencies (
get_current_user_dependency()) - Repositories for experiments, samples, users, etc.
- Platform configuration
async def initialize(self, context=None):
self._context = context
if context:
# Running integrated - use platform services
self.experiment_repo = context.get_experiment_repository()
else:
# Running standalone
pass
Installation Commands
# Install from GitHub
uv add git+https://github.com/org/mld-plugin-example
# Install specific version
uv add git+https://github.com/org/mld-plugin-example@v1.0.0
# Install from PyPI
uv add mld-plugin-example
# Install local plugin for development
uv add --editable ./my-plugin
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mld_sdk-0.11.4.tar.gz.
File metadata
- Download URL: mld_sdk-0.11.4.tar.gz
- Upload date:
- Size: 136.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","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":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
11ae2c18f0a831ae5a151d3e8cde307eda7ec4912a51d654980a29d33c8d5506
|
|
| MD5 |
fad6250a91095dc7aa063361859b6ed5
|
|
| BLAKE2b-256 |
36659d20a5a98b0c73550dc7911555ced98def53bfc868c7e78d62fe962e69d8
|
File details
Details for the file mld_sdk-0.11.4-py3-none-any.whl.
File metadata
- Download URL: mld_sdk-0.11.4-py3-none-any.whl
- Upload date:
- Size: 111.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","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":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f7471620c240acd6369032697b0b1ad395af55e860fe166f73a908c318c35308
|
|
| MD5 |
f6fa0ddfbafac02c62104c2a9dfa9246
|
|
| BLAKE2b-256 |
5e876aa4c1abc43499361a28d5a8b4699c43565d84a09bed316e70c003f914b4
|