Skip to main content

Moderators: One package to moderate them all

Project description

Moderators

Moderators PYPI Moderators HuggingFace Space Moderators CI Moderators License

Run open‑source content moderation models (NSFW, toxicity, etc.) with one line — from Python or the CLI. Works with Hugging Face models or local folders. Outputs are normalized and app‑ready.

  • One simple API and CLI
  • Use any compatible Transformers model from the Hub or disk
  • Normalized JSON output you can plug into your app
  • Optional auto‑install of dependencies for a smooth first run

Note: Today we ship a Transformers-based integration for image/text classification.

Who is this for?

Developers and researchers/academics who want to quickly evaluate or deploy moderation models without wiring different runtimes or dealing with model‑specific output formats.

Installation

Pick one option:

Using pip (recommended):

pip install moderators

Using uv:

uv venv --python 3.10
source .venv/bin/activate
uv add moderators

From source (cloned repo):

uv sync --extra transformers

Requirements:

  • Python 3.10+
  • For image tasks, Pillow and a DL framework (PyTorch preferred). Moderators can auto‑install these.

Quickstart

Run a model in a few lines.

Python API:

from moderators.auto_model import AutoModerator

# Load from the Hugging Face Hub (e.g., NSFW image classifier)
moderator = AutoModerator.from_pretrained("viddexa/nsfw-mini")

# Run on a local image path
result = moderator("/path/to/image.jpg")
print(result)

CLI:

moderators viddexa/nsfw-mini /path/to/image.jpg

Text example (sentiment/toxicity):

moderators distilbert/distilbert-base-uncased-finetuned-sst-2-english "I love this!"

What do results look like?

You get a list of normalized prediction entries. In Python, they’re dataclasses; in the CLI, you get JSON.

Python shape (pretty-printed):

[
  PredictionResult(
    source_path='',
    classifications={'NSFW': 0.9821},
    detections=[],
    raw_output={'label': 'NSFW', 'score': 0.9821}
  ),
  ...
]

JSON shape (CLI output):

[
  {
    "source_path": "",
    "classifications": {"NSFW": 0.9821},
    "detections": [],
    "raw_output": {"label": "NSFW", "score": 0.9821}
  }
]

Tip (Python):

from dataclasses import asdict
from moderators.auto_model import AutoModerator

moderator = AutoModerator.from_pretrained("viddexa/nsfw-mini")
result = moderator("/path/to/image.jpg")
json_ready = [asdict(r) for r in result]
print(json_ready)

Example: Real output on a sample image

Image source:

Example input image

Raw model scores:

[
  { "normal": 0.9999891519546509 },
  { "nsfw": 0.000010843970812857151 }
]

Moderators normalized JSON shape:

[
  { "source_path": "", "classifications": {"normal": 0.9999891519546509}, "detections": [], "raw_output": {"label": "normal", "score": 0.9999891519546509} },
  { "source_path": "", "classifications": {"nsfw": 0.000010843970812857151}, "detections": [], "raw_output": {"label": "nsfw", "score": 0.000010843970812857151} }
]

Comparison at a glance

The table below places Moderators next to the raw Transformers pipeline() usage.

Feature Transformers.pipeline() Moderators
Usage pipeline("task", model=...) AutoModerator.from_pretrained(...)
Model configuration Manual or model-specific Automatic via config.json (task inference when possible)
Output format Varies by model/pipe Standardized PredictionResult / JSON
Requirements Manual dependency setup Optional automatic pip/uv install
CLI None or project-specific Built-in moderators CLI (JSON to stdout)
Extensibility Mostly one ecosystem Open to new integrations (same interface)
Error messages Vary by model Consistent, task/integration-guided
Task detection User-provided Auto-inferred from config when possible

Pick a model

  • From the Hub: pass a model id like viddexa/nsfw-mini or any compatible Transformers model.
  • From disk: pass a local folder that contains a config.json next to your weights.

Moderators detects the task and integration from the config when possible, so you don’t have to specify pipelines manually.

Command line usage

Run models from your terminal and get normalized JSON to stdout.

Usage:

moderators <model_id_or_local_dir> <input> [--local-files-only]

Examples:

  • Text classification:
    moderators distilbert/distilbert-base-uncased-finetuned-sst-2-english "I love this!"
    
  • Image classification (local image):
    moderators viddexa/nsfw-mini /path/to/image.jpg
    

Tips:

  • --local-files-only forces offline usage if files are cached.
  • The CLI prints a single JSON array (easy to pipe or parse).

Examples

  • Small demos and benchmarking script: examples/README.md, examples/benchmarks.py

FAQ

  • Which tasks are supported?
    • Image and text classification via Transformers (e.g., NSFW, sentiment/toxicity). More can be added over time.
  • Does it need a GPU?
    • No. CPU is fine for small models. If your framework has CUDA installed, it will use it.
  • How are dependencies handled?
    • If something is missing (e.g., torch, transformers, Pillow), Moderators can auto‑install via uv or pip unless you disable it. To disable:
      export MODERATORS_DISABLE_AUTO_INSTALL=1
      
  • Can I run offline?
    • Yes. Use --local-files-only in the CLI or local_files_only=True in Python after you have the model cached.
  • What does “normalized output” mean?
    • Regardless of the underlying pipeline, you always get the same result schema (classifications/detections/raw_output), so your app code stays simple.

Roadmap

What’s planned:

  • Ultralytics integration (YOLO family) via UltralyticsModerator
  • Optional ONNX Runtime backend where applicable
  • Simple backend switch (API/CLI flag, e.g., --backend onnx|torch)
  • Expanded benchmarks: latency, throughput, memory on common tasks
  • Documentation and examples to help you pick the right option

Troubleshooting

  • ImportError (PIL/torch/transformers):
    • Install the package (pip install moderators) or let auto‑install run (ensure MODERATORS_DISABLE_AUTO_INSTALL is unset). If you prefer manual dependency control, install extras: pip install "moderators[transformers]".
  • OSError: couldn’t find config.json / model files:
    • Check your model id or local folder path; ensure config.json is present.
  • HTTP errors when pulling from the Hub:
    • Verify connectivity and auth (if private). Use offline mode if already cached.
  • GPU not used:
    • Ensure your framework is installed with CUDA support.

License

Apache-2.0. 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

moderators-0.1.0.tar.gz (25.6 kB view details)

Uploaded Source

Built Distribution

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

moderators-0.1.0-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file moderators-0.1.0.tar.gz.

File metadata

  • Download URL: moderators-0.1.0.tar.gz
  • Upload date:
  • Size: 25.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for moderators-0.1.0.tar.gz
Algorithm Hash digest
SHA256 f47dbc3bb21c7e15f5ede72df82b889dde46b5018d7908aee36adc999bc304a0
MD5 7cd71d4cac8ee5c495448708d8044770
BLAKE2b-256 bc3b5d4974e9ede56c1f9bf2dfcce68b22d464040a5999ed575f8a580704618a

See more details on using hashes here.

Provenance

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

Publisher: publish.yml on viddexa/moderators

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

File details

Details for the file moderators-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: moderators-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 21.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for moderators-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9dcdf9a1c934a907cd52f934a5363d92aaf9a2e48c21ec5c42468960c9f63fbd
MD5 2a946bd662a4752ee06d3c7912a867b9
BLAKE2b-256 0c9813f36ba34747623195f123aa9b1ff30f889284237acbe9f6fe4ddc4ec6ec

See more details on using hashes here.

Provenance

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

Publisher: publish.yml on viddexa/moderators

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