Scheduled RSS to Email with Github Actions
Find a file
2024-11-05 23:04:38 +08:00
.github/workflows Update send-email.yaml 2024-11-05 13:05:39 +08:00
public Parse html (#43) 2023-01-24 08:44:07 +01:00
src Update feeds.ts 2024-11-05 23:04:38 +08:00
.gitignore Last success (#13) 2023-01-22 10:14:55 +01:00
.prettierignore prettier ignore (#50) 2023-01-25 06:43:39 +01:00
.prettierrc.json Setting up the project 2023-01-20 08:54:01 +01:00
email.js Last success (#13) 2023-01-22 10:14:55 +01:00
index.html Update some formatting issues since latest prettier 2023-12-15 04:40:28 +01:00
LICENSE Initial commit 2023-01-20 08:50:16 +01:00
package-lock.json Update non-major dependencies (#343) 2024-10-26 14:16:14 +02:00
package.json Update non-major dependencies (#343) 2024-10-26 14:16:14 +02:00
README.md Add intro post link to readme (#48) 2023-01-24 11:03:31 +01:00
renovate.json bundle all renovate updates 2023-11-23 09:21:20 +01:00
screenshot.png Update screenshot (#45) 2023-01-24 08:52:30 +01:00
server.js Better feed error handling (#38) 2023-01-23 09:57:22 +01:00
tsconfig.json Setting up the project 2023-01-20 08:54:01 +01:00
tsconfig.node.json Setting up the project 2023-01-20 08:54:01 +01:00
vite.config.ts Better feed error handling (#38) 2023-01-23 09:57:22 +01:00

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

  • Github workflow runs on a schedule
  • Workflow retrieves updates from your RSS feeds since its last successful run
  • Workflow sends the updates through a SMTP server of your choice

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 💪
⚠️ 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

🔥 your data stays in your own Github account

❄️ fully customizable email

📅 receive the updates when and where you want

💩 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

  • react-email
    This project is what triggered me to create this repo. It is still very beta, but if we can ditch all the clunky specialized tools for creating email layouts and replace them with a React / Typescript based solution ❤️
  • vite
    For rendering and the dev server. Had to do some hacking to get it working well with HMR and my cache implementation is 💩. But Vite itself is 🔥
  • dawidd6/action-send-mail
    Github Action to send out emails, just bring your own SMTP provider