Skip to main content

huggingface_hub but for CivitAI — inspect and download models/LoRAs

Project description

civitai-hub

CI Python Ruff

huggingface_hub, but for CivitAI. Point it at a model URL to inspect what's inside (type, base/parent model, every file with sizes and hashes) and download the checkpoint or LoRA into a deduplicated, content-addressed cache — usable as both a CLI and an importable Python library.

$ civitai download https://civitai.com/models/580857 --fp16 -o ~/ComfyUI/models/loras
~/ComfyUI/models/loras/realistic-skin-xl.safetensors

civitai info — model type, base model, and a table of every file
civitai info <url> — what's inside a model at a glance

Contents: Features · Install · CLI · Library · Auth · Configuration · How it works · Docker · Development

Features

  • Inspect before you fetchcivitai info <url> shows the model type, base/parent model, the selected version, and a table of every file in it (size, format, precision, hash, scan status).
  • Smart, scriptable downloads — picks the URL-pinned version (or the latest) and its primary file by default; override with --version-id, --fp16/--fp32, --pruned/--full, --format, --file, or grab everything with --all.
  • Find the base modelcivitai base <lora-url> lists the checkpoints a LoRA's base-model family runs on (CivitAI only exposes the family name, not a direct link), with --download N to grab one.
  • Discover & identifycivitai search finds models from the terminal; civitai by-hash <file> tells you what an orphaned .safetensors actually is.
  • Manage itcivitai cache ls/verify/rm/prune for the local store, civitai login to save your token, --json on every command for scripting.
  • Managed cache like HF Hub — content-addressed blobs keyed by SHA256, with per-version snapshot symlinks. The same file reused across versions is stored once. Re-downloads are skipped.
  • Resumable & verified — HTTP range-resume for interrupted downloads, automatic SHA256 verification, and a live progress bar.
  • Library + CLI — everything the CLI does is a one-line call from Python.
  • Safe by default — blocks files flagged unsafe by CivitAI's scanners (override with --allow-unscanned) and fails fast on early-access/gated content with a clear message.

Install

From PyPI (recommended):

pipx install civitai-hub        # isolated CLI
pip install civitai-hub         # into the current environment

With Docker — no install needed:

docker run --rm ghcr.io/mr8bit/civit-ai-cli info 580857

From a GitHub release (without PyPI) — pin a tag from the releases page:

pipx install "git+https://github.com/mr8bit/civit-ai-cli@v0.2.1"

For development from a clone:

python -m venv .venv && source .venv/bin/activate
pip install -e ".[dev]"

CLI quickstart

# Inspect a model (human table, or --json for machines)
civitai info https://civitai.com/models/580857/realistic-skin
civitai info 580857 --json

# Download the primary file of the latest (or URL-pinned) version
civitai download https://civitai.com/models/580857

# Drop a specific precision straight into your ComfyUI/A1111 folder
civitai download 580857 --fp16 -o ~/ComfyUI/models/loras

# Preview what would be fetched without downloading
civitai download 580857 --dry-run

# Grab every file in the version
civitai download 580857 --all

# Find the base checkpoints a LoRA runs on, then grab one
civitai base 580857
civitai base 580857 --download 1 -o ~/ComfyUI/models/checkpoints

# Search, then identify a mystery file on disk
civitai search "realistic" --type Checkpoint --base-model "SDXL 1.0" --limit 10
civitai by-hash ~/ComfyUI/models/loras/mystery.safetensors

# Save your token; manage the cache
civitai login                       # prompts for the API key (or --token)
civitai cache ls
civitai cache verify
civitai cache rm 580857

civitai base — ranked base checkpoints for a LoRA's base-model family
civitai base <url> — the checkpoints a LoRA runs on, most-downloaded first

The downloaded path is printed to stdout (the progress bar goes to stderr), so it pipes cleanly:

MODEL=$(civitai download 580857 --no-progress)

Library usage

import civitai_hub

# Inspect
info = civitai_hub.model_info("https://civitai.com/models/580857")
print(info.model.type, info.version.base_model, len(info.files))

# Download — returns the local Path (or list[Path] with all=True)
path = civitai_hub.download(
    "https://civitai.com/models/580857",
    fp="fp16",
    local_dir="~/ComfyUI/models/loras",
)

download(...) mirrors hf_hub_download (single file) and snapshot_download (all=True).

Authentication

Most public files download without a token. For gated, NSFW, or early-access resources, create an API key in your CivitAI account settings and provide it via:

export CIVITAI_TOKEN=<your key>     # or pass --token <key>

Configuration

Precedence is flag → environment variable → default.

Setting Flag Env var Default
API token --token (download/base) CIVITAI_TOKEN (anonymous)
Cache root --cache-dir (download/base) CIVITAI_HOME platform cache dir (~/.cache/civitai on Linux)
Offline (cache only) CIVITAI_OFFLINE off
Copy instead of symlink --no-symlinks (download) CIVITAI_DISABLE_SYMLINKS symlinks on
Disable progress bar --no-progress (download/base) CIVITAI_NO_PROGRESS progress on

The flags live on download/base; civitai info takes only --version-id/--json and reads the env vars for everything else.

How it works

A model URL resolves to one GET /api/v1/models/{id} call; the version is the URL's pinned modelVersionId (or the latest published one), and the file is that version's primary .safetensors unless you filter it. Downloads go only to civitai.com (the host is checked first) and authenticate with the Authorization header — httpx strips it on the cross-host CDN redirect, so the token never leaves civitai.com or lands in a URL. The download is SHA256-verified and lands in the cache:

$CIVITAI_HOME/
└── models/<modelId>/
    ├── blobs/<sha256>                      # content-addressed, deduplicated
    └── snapshots/<versionId>/<filename>    # symlink → ../../blobs/<sha256>

--local-dir then materializes a symlink (or copy) of the blob into the folder you choose.

For the full command/flag reference, cache details, troubleshooting, and exit codes, see docs/usage.md.

Docker

Prebuilt multi-arch images are published to the GitHub Container Registry on every release:

# inspect a model
docker run --rm ghcr.io/mr8bit/civit-ai-cli info 580857

# download into a host folder (mount it as the cache + output)
docker run --rm -v "$PWD/models:/data" \
  ghcr.io/mr8bit/civit-ai-cli download 580857 -o /data

# pass a token for gated content
docker run --rm -e CIVITAI_TOKEN="$CIVITAI_TOKEN" \
  ghcr.io/mr8bit/civit-ai-cli base 580857

The cache lives at /data inside the image (CIVITAI_HOME) — mount a volume there to persist downloads. Build it yourself with docker build -t civitai-hub ..

Development

pip install -e ".[dev]"
pytest                 # full suite (offline; httpx mocked with respx)
pytest tests/test_resolver.py::test_fp_selector -v   # a single test
ruff check src tests   # lint
CIVITAI_LIVE=1 pytest tests/test_live.py -v           # opt-in test against the real API

See CONTRIBUTING.md for the architecture overview and conventions, and docs/superpowers/specs/ + docs/superpowers/plans/ for the original design and implementation plan.

License

MIT © Artemiy Mazaew

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

civitai_hub-0.3.0.tar.gz (33.2 kB view details)

Uploaded Source

Built Distribution

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

civitai_hub-0.3.0-py3-none-any.whl (24.3 kB view details)

Uploaded Python 3

File details

Details for the file civitai_hub-0.3.0.tar.gz.

File metadata

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

File hashes

Hashes for civitai_hub-0.3.0.tar.gz
Algorithm Hash digest
SHA256 54457a83b676c07d1f98d8d76a3df8973e7009536263576553439b6ef0afdb61
MD5 2e096c9cfc0a9f774a31c9f02bbaa470
BLAKE2b-256 74831d4dc78fda29fae2e7f63f0f72bfd7694cc27eb21d88492e08f553fa4ea8

See more details on using hashes here.

Provenance

The following attestation bundles were made for civitai_hub-0.3.0.tar.gz:

Publisher: publish.yml on mr8bit/civit-ai-cli

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

File details

Details for the file civitai_hub-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: civitai_hub-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 24.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for civitai_hub-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1437c7790d01f933df0dc98c27e6bbea385c6989af7a8acb684f3195fe84555a
MD5 871e21b45d5bb6d9e65cf36e06006d31
BLAKE2b-256 f2881de88d505a957b5c283229c7ccbef5ac78078486b41db6c69e6d45a7fd9e

See more details on using hashes here.

Provenance

The following attestation bundles were made for civitai_hub-0.3.0-py3-none-any.whl:

Publisher: publish.yml on mr8bit/civit-ai-cli

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