bdevos / rss-to-email

Scheduled RSS to Email with Github Actions
MIT License
31 stars 26 forks source link
actions cron cronjob email email-template github-actions react react-email rss rss-aggregator vite

RSS to Email

Stay on top of your favorite RSS feeds - on your own terms. This project allows you to set up custom email updates based on the RSS feeds you specify, all within the comfort of your own Github account.

Say goodbye to constantly checking for updates, and hello to staying informed on your own schedule.

Introductory post on my blog

How does it work

Getting started

  1. Fork this repository
  2. Update feeds.ts with your favorite RSS feed(s)
  3. Update the cron schedule in the workflow file
  4. Add the following repository variables in settings:
    • SMTP_SERVER for example: smtp.gmail.com
    • SMTP_PORT for example: 587
  5. Add the following repository secrets in settings:
    • MAIL_TO the mail address to send the email to
    • SMTP_USERNAME
    • SMTP_PASSWORD
  6. Done :muscle:
:warning: The above variables and secrets can also be changed directly in the workflow, but be aware that if your repo is public that this could expose your credentials.

Pro and cons

:fire: your data stays in your own Github account

:snowflake: fully customizable email

:date: receive the updates when and where you want

:poop: might have to do some tweaking

Cron schedule

Use crontab guru to play around with the cron schedule that works best for you.

Some example schedules:

cron description
0 6 * * * every day at 06:00
0 9-18 * * 1-5 monday to friday every hour from 09:00 to 18:00
0 10 * * 6 saturday at 10:00
0/15 * * * * every 15 minutes

Because the workflow looks at the previous successful run to determine which posts to send you, you can also disable the workflow by hand and pickup again later. There might be a limit to the amount of posts in a single RSS feed.

Note: Github workflow runs do not support timezones for cron schedules.

Screenshot

Below is a screenshot of how the Daring Fireball updates use custom styling and my own blog has a generic style.

Example of the email

Local dev server

This project includes a local dev server to view and modify the email template based on your RSS feeds.

Start the dev server:

npm install
npm run dev

How does it work

Rendering the email starts in the renderEmail function. It will retrieve and parse the feeds, and trigger rendering the email with the Email component.

Build on top of