A tool that generates concise summaries for you Miniflux feeds.
Project description
minigist
AI-powered summaries for your Miniflux feeds.
Turn your long Miniflux articles into clear, concise summaries.
✨ Why minigist?
Long-form feed entries are great for depth but hard to keep up with. Miniflux shows the full content, and without a summary layer you still have to read everything to decide what matters.
minigist solves this by generating concise summaries on the server side and writing them directly into each unread entry. This works with your current way to read Miniflux entries, no client changes needed.
🧠 How it works
- You define prompts and targets in a YAML config file
- minigist fetches the full text of unread entries (using pure.md if configured)
- Your configured LLM generates summaries using your prompts
- Summaries are written back into the Miniflux entry
🚀 Installation
Install minigist using pip:
pip install minigist
Install minigist using uv:
uv tool install minigist
📄 Usage
Configuration
Find below an example config file. By default, minigist searches for a config file in this order:
~/.config/minigist/config.yaml~/.config/minigist/config.yml./config.yaml./config.yml/etc/minigist/config.yaml/etc/minigist/config.yml
You can override the path with the --config-file flag.
For credentials, you can set environment variables to override the YAML values:
MINIGIST_MINIFLUX_API_KEY→miniflux.api_keyMINIGIST_LLM_API_KEY→llm.api_key
miniflux:
# Base URL of your Miniflux instance (required)
url: "https://your-miniflux-instance.com"
# Miniflux API key (required)
api_key: "your-miniflux-api-key"
# Request timeout in seconds (optional; default: 2)
timeout_seconds: 2
llm:
# API key for your LLM provider (required)
api_key: "your-ai-service-api-key"
# API base URL (optional; default: OpenRouter)
base_url: "https://openrouter.ai/api/v1"
# Model identifier to use (optional; default shown)
model: "google/gemini-2.5-flash-lite"
# Request timeout in seconds (optional; default: 60)
timeout_seconds: 60
# Max number of concurrent LLM requests (optional; default: 5)
concurrency: 5
prompts:
# Prompts define how summaries are produced.
# Each prompt must have a unique id.
- id: "default"
prompt: "Generate an executive summary of the provided article."
- id: "deep-dive"
prompt: "Extract the nuanced arguments and counterpoints."
# minigist always appends a fixed system instruction that enforces JSON output
# and requires summary_markdown to be Markdown. This cannot be overridden.
# Optional: when no targets are defined, this prompt is used for all unread entries.
# If omitted, the first prompt in the "prompts" list is used.
default_prompt_id: "default"
targets:
# Targets map feeds or categories to prompts.
# When targets are defined, ONLY these feeds/categories are processed.
# Overlaps across targets are errors.
- prompt_id: "default"
feed_ids: [1, 2]
- prompt_id: "deep-dive"
category_ids: [5]
# Prefer pure.md for this target (optional; default: false)
use_pure: true
scraping:
# Token for pure.md (optional; improves rate limits)
pure_api_token: "optional-pure-md-token"
# Always route matching URLs through pure.md
pure_base_urls:
- "https://text.npr.org/"
# Request timeout for scraping in seconds (optional; default: 5)
timeout_seconds: 5
fetch:
# Max unread entries to fetch per feed (optional; default: 50)
limit: 50
notifications:
# Apprise notification URLs for error/failure alerts (optional)
- "discord://webhook_id/webhook_token"
- "telegram://bot_token/chat_id"
[!NOTE] Notifications are only sent for errors or runs that finish with failures; summaries are not pushed as notifications.
See Apprise documentation for all supported notification services.
Run
Run minigist to process unread entries:
minigist run
Run in dry-run mode to see what would happen without making changes:
minigist run --dry-run
Increase logging verbosity:
minigist run --log-level DEBUG
Use a different configuration file:
minigist run --config-file /path/to/config.yaml
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 minigist-0.9.2.tar.gz.
File metadata
- Download URL: minigist-0.9.2.tar.gz
- Upload date:
- Size: 27.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","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 |
865e176ca82b5cb8c64c66899696ec507c257e575fc5b2b77af15882d93e1d55
|
|
| MD5 |
eb58ac0e74b45b86719e79bf60ae1beb
|
|
| BLAKE2b-256 |
163f4410b800f1b11dcbbce6fb46d267cbb95944038416155edbbcc9d00d5501
|
File details
Details for the file minigist-0.9.2-py3-none-any.whl.
File metadata
- Download URL: minigist-0.9.2-py3-none-any.whl
- Upload date:
- Size: 27.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","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 |
249d9fdb6c8b4b6a4599d8760ec456fb0e8130f909e36f2ed293c580fd901787
|
|
| MD5 |
f315112890364fa73129713397dda680
|
|
| BLAKE2b-256 |
2457853717347e0551078f8c0ef69a2c64c3bef7e037e34709289f6111031d1e
|