1 unstable release
0.1.0 | Mar 7, 2021 |
---|
#13 in #mdbook-preprocessor
26KB
232 lines
mdbook-rss
A preprocessor for mdBook that generates an RSS feed from your chapters.
The code is built on the example from the documentation.
Usage and Configuration
First, make sure to install this to your $PATH
so mdbook
can find and use it:
cargo install --git <url to this repository>
Configuration: Feed
This section describes "global" configuration for the feed itself.
mdbook-rss
looks for a [preprocessor.rss]
section in your book.toml:
[preprocessor.rss]
files-glob = "posts/*.md"
url-base = "https://example.com/"
Available configuration keys taken from the book.toml:
files-glob
: A file glob used to specify which files to include in the RSS feedurl-base
: A URL that, in combination with the files' path is used to build links to the articles.
Basically this is a combination of the domain where the mdbook is hosted and the book'ssite-url
option.
Note that due to implementation detail ofurl::Url::join
this should end with a '/'.
The resulting RSS feed is written to an rss.xml
file next to your SUMMARY.md
, so it can be accessed via <url-base>/rss.xml
.
Configuration: Book Chapters and RSS Items
This section describes configuration on a per-chapter base.
In addition to global configuration, you may configure some attributes of each of your book's chapters, by defining a front matter like this:
---
pub_date: Wed, 03 Mar 2021 12:00:00 GMT
description: A helpful example
---
# Example
Rest of your markdown
Currently only pub_date
and description
are supported with the description being optional.
NOTE: This front matter ist removed from each chapter, so it won't be available anymore for preprocessors running after this one!
Known Issues/Potential Improvements
- There are now actual tests yet. The only testing I did was checking the resulting feed in a feed reader.
- The RSS items' content is HTML rendered by this preprocessor using the markdown crate; this means mdbook-specific features may be rendered incorrectly in the generated RSS feed.
- Front matter is removed which makes it unavailable/incompatible with other preprocessors running after this which also use front matter.
Keep front matter and remove it with a separate preprocessor used for removing front matter? - This preprocessor currently assumes each RSS item is written by the same person(s) and just comma-separates the book's
authors
field for each RSS item.
This could be overridden in front matter? - The titles for the RSS feed itself and each item is taken from the book and chapters.
This could be overridden in book.toml and front matter?
License
The code in this repository is released under the Mozilla Public License Version 2.0.
Dependencies
~21–34MB
~584K SLoC