Skip to content

Fast, all-in-one parser and generator for RSS, Atom, RDF, and JSON Feed, with support for Podcast, iTunes, Dublin Core, and OPML files.

License

Notifications You must be signed in to change notification settings

macieklamberski/feedsmith

Repository files navigation

Feedsmith

tests codecov npm version license

Fast, all‑in‑one JavaScript parser and generator for RSS, Atom, RDF, and JSON Feed, with support for popular namespaces and OPML files.

Feedsmith offers universal and format‑specific parsers that maintain the original feed structure in a clean, object-oriented format while intelligently normalizing legacy elements. Access all feed data without compromising simplicity.

Read full docs ↗   ·   Quick Start   ·   Why Feedsmith?   ·   Benchmarks →


Features

Core

  • Comprehensive support 🎯 — Supports all major feed formats and namespaces.
  • Preserves structure 📦 — Parsed feed object maintains the original feed structure making it easy to access the data.
  • Smart namespace handling 🧠 — Normalizes custom namespace prefixes to standard ones (e.g., <custom:creator> becomes dc.creator).
  • Parsing & generating 🔩 — Use one package for both parsing and generating feeds.

Leniency

  • Normalizes legacy elements ✨ — Upgrades feed elements to their modern equivalents so that you never need to worry about reading feeds in older formats.
  • CaSe INSENsiTive 🐍 — Handles fields and attributes in any case (lowercase, uppercase, mixed).
  • Forgiving 🤝 — Gracefully handles malformed or incomplete feeds and extracts valid data. This makes it suitable for use with real-world feeds that may not strictly follow specifications.

Performance and Type-Safety

  • Ultrafast parsing ⚡ — One of the fastest JavaScript feed parsers (see benchmarks).
  • Type-safe API 🛟 — Built with TypeScript from the ground up, it provides complete type definitions for every feed format and namespace.
  • Tree-shakable 🍃 — Only include the parts of the library you need, reducing bundle size.
  • Well-tested 🔬 — Comprehensive test suite with over 2000 tests and 99% code coverage.

Compatibility

  • Works in Node.js 14.0.0+ and modern browsers.
  • Supports both CommonJS and ES modules.
  • Works with plain JavaScript, you don't need to use TypeScript.

Supported Formats

Feedsmith aims to fully support all major feed formats and namespaces in complete alignment with their specifications.

✅ Available   ·   ⌛️ Work in progress   ·   📋 Planned

Feeds

Format Versions Parsing Generating
RSS 0.9x, 2.0
Atom 0.3, 1.0
RDF 0.9, 1.0
JSON Feed 1.0, 1.1

Namespaces

Name Prefix Supported in Parsing Generating
Atom <atom:*> RSS, RDF
Dublin Core <dc:*> RSS, Atom, RDF
Syndication <sy:*> RSS, Atom, RDF
Content <content:*> RSS, RDF
Slash <slash:*> RSS, Atom, RDF
iTunes <itunes:*> RSS, Atom
Podcast <podcast:*> RSS
Podlove Simple Chapters <psc:*> RSS, Atom
Media RSS <media:*> RSS, Atom, RDF
GeoRSS-Simple <georss:*> RSS, Atom, RDF
Atom Threading <thr:*> RSS, Atom
Dublin Core Terms <dcterms:*> RSS, Atom, RDF
Well-Formed Web <wfw:*> RSS, Atom, RDF
Source <source:*> RSS
YouTube <yt:*> Atom

Other

Format Versions Parsing Generating
OPML 1.0, 2.0

Quick Start

This guide will get you up and running with Feedsmith in just a few minutes.

For a full overview of all the features, visit the documentation website.

Installation

npm install feedsmith

Migrating from v1.x? Check out the migration guide.

Parse Any Feed

The simplest way to parse any feed is to use the universal parseFeed function:

import { parseFeed } from 'feedsmith'

// Works with RSS, Atom, RDF, and JSON Feed
const { format, feed } = parseFeed(feedContent)

console.log('Feed format:', format) // rss, atom, json, rdf
console.log('Feed title:', feed.title)

if (format === 'rss') {
  console.log('RSS feed link:', feed.link)
}

Parse Specific Feed Formats

If you know the format in advance, you can use the format-specific parsers:

import {
  parseAtomFeed,
  parseJsonFeed,
  parseRssFeed,
  parseRdfFeed
} from 'feedsmith'

// Parse specific formats
const rssFeed = parseRssFeed('rss content')
const atomFeed = parseAtomFeed('atom content')
const rdfFeed = parseRdfFeed('rdf content')
const jsonFeed = parseJsonFeed('json content')

// Access typed data
rssFeed.title
rssFeed.dc?.creator
rssFeed.items?.[0]?.title

Parse OPML Files

import { parseOpml } from 'feedsmith'

const opml = parseOpml('opml content')

opml.head?.title
opml.body?.outlines?.[0].text
opml.body?.outlines?.[1].xmlUrl

Generate a Feed

import { generateRssFeed } from 'feedsmith'

const rss = generateRssFeed({
  title: 'My Blog',
  link: 'https://example.com',
  description: 'A simple blog',
  items: [{
    title: 'Hello World',
    link: 'https://example.com/hello',
    description: 'My first post',
    pubDate: new Date()
  }]
})

console.log(rss) // Complete RSS XML

// You can also generate other formats:
// - generateAtomFeed() for Atom feeds
// - generateJsonFeed() for JSON feeds
// - generateOpml() for OPML files

Handle Errors

try {
  const { format, feed } = parseFeed(content)
  // Use the feed
} catch (error) {
  console.error('Invalid feed:', error.message)
}

Why Feedsmith?

Why should you use this library over the alternatives?

The key advantage of Feedsmith is that it preserves the original feed structure exactly as defined in each specific feed format.

Many alternative packages attempt to normalize data by:

  • Merging distinct fields like author, dc:creator, and creator into a single property.
  • Combining date fields such as dc:date and pubDate without preserving their sources.
  • Handling multiple <atom:link> elements inconsistently, sometimes keeping only the first or last one or ignoring different rel attributes.
  • Some libraries try to combine different feed formats into one universal structure.

While this approach can be useful for quick reading of feed data, it often results in a loss of information that may be crucial for certain applications, such as reading data from specific namespaces.

Acknowledgements

License

Licensed under the MIT license.
Copyright 2025 Maciej Lamberski

About

Fast, all-in-one parser and generator for RSS, Atom, RDF, and JSON Feed, with support for Podcast, iTunes, Dublin Core, and OPML files.

Topics

Resources

License

Stars

Watchers

Forks

Languages