06 February 2024
•
views
how-to
Hosting a RSS Feed on your Next.Js Blog
If you read my article about my reasons for moving my site1, you know that one of the habits I am trying to create for 2024 is to create more and consume less. One of the actions I’ve taken is subscribing to RSS feeds that I care about, instead of mindlessly scrolling news feeds on twitter, Apple News, etc.
I haven’t missed that habit, and it really has limited the amount of stupid things that I find myself sucked into reading.
When I try to build habits that revolve around not doing certain things, the best way to deter those actions is to build friction around it. Using an RSS reader has been some of the friction I’ve introduced.
However, this got me thinking about how I don’t have an RSS feed built into this site. During the first iteration of my web existence, it was one of the features I set out to build, but didn’t quite get around to.
So, without further ado, here is how I went about integrating an RSS feed into my site.
Pre-Requisites
These aren’t so much pre-requisites as they are just statements about the system that I am building this feature into. There are two system-specific pieces of information that provide important context.
- This site uses Next.Js. Most of this logic can be extracted and generalized into any static site generator.
- My articles are made developer friendly using contentlayer2. Again, just a personal choice, but any list of your articles/post and their relevant metadata will suffice (whether that comes from a CMS or repository).
General Framework
Just so everyone is on the same page, all an RSS feed is, is a xml
file that is hosted on your site. It contains all relevant information and metadata about your posts for feed readers to parse out. So conceptually, there are two steps to building this out.
- We need to generate the xml file.
- We need to host the file on our site.
Implementation
To generate the feed, I am going to use the help of the node package feed3. You can take a look at the options to configure with its Github repo.
Now when it comes to serving the file, the Next.Js server route handlers4 are a near perfect use case for this.
If you’re using the /app
directory, create a new folder called rss.xml
, and within it, a file called route.ts
.
Within this file, we are going to handle any GET
https request to the rss.xml
path on your site. Let’s first define the function that generates the feed.
Above, we have created a feed object. All that’s left is to add all of the posts. Because we are set up using contentlayer, we can import the allPosts
object, filter and sort however we’d like, and then add each to the feed.
Finally, handle the get route
Now, you can link to /rss.xml
anywhere on your site and have the end user redirected to the feed url to give to their RSS reader.
Footnotes
Metadata
Published
February 06, 2024
Tags
rss, next.js, coding