A tool to generate ebooks from Omnivore articles
Project description
Omnivook, omnivore articles as a (daily) book 📚
Automates the process of generating an eBook from Omnivore articles and sending it via email to your Kindle device.
Usage
The easiest way of running the latest version is using uv.
For a one-time run:
OMNIVORE_APIKEY=<key> uvx omnivook
To install it permanently, use
uv tool install omnivook
To upgrade it:
uv tool upgrade omnivook
Then simply run
OMNIVORE_APIKEY=<key> omnivook
By default it will generate an epub with the articles since the day before.
Pass --help
to see all the options.
Alternatively, you can install omnivook
with pipx, pip, etc.
Automated daily ebook via email ⏰: Setup Github Action
Clone this repo and configure the following GitHub Secrets in your repository:
OMNIVORE_APIKEY
: Get yours at https://omnivore.app/settings/apiMAIL_CONNECTION
: The SMTP connection URL in the format:smtp://user:password@server:port
. If this is set, you don't need to provideSERVER
,USERNAME
,PASSWORD
,SERVER_PORT
, orSECURE
.MAIL_FROM
: The email address from which the eBook will be sent.MAIL_TO
: The Kindle email address where the eBook will be delivered.
Alternatively, if MAIL_CONNECTION
is not set, you can configure the following secrets individually:
SERVER
: The SMTP server address.USERNAME
: The SMTP username.PASSWORD
: The SMTP password.SERVER_PORT
: The SMTP server port (optional, defaults to465
).SECURE
: Whether the SMTP connection is secure (optional, defaults totrue
).
This setup relies on the action-send-mail GitHub Action for sending emails.
You can overwrite these environment variables if you want to change the dynamic setup of:
PROJECT_NAME
= a.k.a the file name of the epub. Default to omnivook_since_<DATE>
to<DATE>
.epubEPUB_TITLE
: a.k.a the title of the document. Default to omnivook since<DATE>
to<DATE>
EPUB_AUTHORS
: a.k.a List of site names of all the articles. Default set to the repo owner
Manual Trigger 🔧
You can manually trigger the workflow from the GitHub Actions tab. When triggering manually, you have the following options:
- SINCE: Specify the start date to filter articles (format
YYYY-MM-DD
). If not provided, defaults to the previous day. - archive: A boolean flag (
true
orfalse
) that determines whether to archive the articles after processing. Defaults totrue
. - label: (optional) Specify a label to filter articles.
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
Built Distribution
File details
Details for the file omnivook-0.1.5.tar.gz
.
File metadata
- Download URL: omnivook-0.1.5.tar.gz
- Upload date:
- Size: 6.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 253c2e30f12ca193eed84d3f0f3786765d622dcb4464249198bdfa2ee5bcc173 |
|
MD5 | 901029e06e1f4b7e0f980e7863c5fdb8 |
|
BLAKE2b-256 | 861cb0c8ee8a7b2b1e09765bed7f1c8ee56a097c1a4b95a339af48101f4c7175 |
File details
Details for the file omnivook-0.1.5-py3-none-any.whl
.
File metadata
- Download URL: omnivook-0.1.5-py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 580b8b1ff320b7fce4fdacc24c6451b91915f9b545467ff320633e396b2aa5da |
|
MD5 | 2ace93b9b8dbfce8d9727419a561c4ca |
|
BLAKE2b-256 | e62e9b6e76dd87a12f2a902a368f193465317749ab96ee888144c2dcb8c95898 |