Aggregates news feed updates and sends them to your email inbox.
- Supports Atom and RSS feeds.
- Supports subscribing to feed directly, or scanning for a
link
tag at a given URL. - Uses Golang html/template to customize the email body.
- Update timestamps persisted to YAML file.
- Install via
go install github.com/fgeller/feeder
or download a release. - Create a config file, customizing email settings and file paths.
- Add subscribed feeds either by:
- maintaing the feeds config file manually, or
- using feeder via
feeder -config cfg.yml -subscribe https://example.com/blog/
- Run via
feeder -config cfg.yml
manually, or set up recurring execution, e.g. viacrontab -e
feeder -help
output:
Usage of feeder:
-config string
Path to config file (required)
-subscribe string
URL to feed to subscribe to
-version
Print version information
By default feeder will try to download the configured feeds and send
the latest entries via email. If the subscribe flag is provided,
instead of downloading feeds, feeder tries to subscribe to the feed
at the given URL and persists the augmented feeds config.
-
feeds-file
is the list of feeds you are subscribed to. -
timestamp-file
is required to persist what updates have been seen. -
email-template-file
is an optional Golang html/template to format the sent email. -
email
contains the configuration for sending emails. Thefrom
address will also be theto
address and thesmtp
object allows for standard smtp host and auth configuration. -
max-entries-per-feed
is the maximum number of entries to send per feed.
feeds-file: '/home/fgeller/.config/feeder/feeds.yml'
timestamp-file: '/home/fgeller/.config/feeder/timestamps.yml'
email-template-file: '/home/fgeller/.config/feeder/email.tmpl'
email:
from: [email protected]
smtp:
host: smtp.gmail.com
port: 587
user: [email protected]
pass: passwort
- name: 'irreal'
url: https://irreal.org/blog/?feed=rss2
- name: The Go Blog
url: https://blog.golang.org/feed.atom