32 releases (15 stable)

2.3.1 Dec 25, 2024
2.2.0 Nov 17, 2024
2.1.0 Jul 19, 2024
1.5.3 May 26, 2024
0.1.3 Jul 7, 2017

#59 in Web programming

Download history 1140/week @ 2024-09-22 1112/week @ 2024-09-29 981/week @ 2024-10-06 787/week @ 2024-10-13 1207/week @ 2024-10-20 1258/week @ 2024-10-27 1765/week @ 2024-11-03 744/week @ 2024-11-10 1885/week @ 2024-11-17 1042/week @ 2024-11-24 1805/week @ 2024-12-01 1548/week @ 2024-12-08 1611/week @ 2024-12-15 828/week @ 2024-12-22 621/week @ 2024-12-29 620/week @ 2025-01-05

3,828 downloads per month
Used in 32 crates (28 directly)

MIT license

255KB
4.5K SLoC

feed-rs

Build Status Crates.io Status

Library for parsing various forms of feeds such as Atom, RSS and JSON Feed. It also supports extensions such as iTunes, Dublin Core and Media RSS and serialisation/deserialisation via serde.

Documentation

Usage

Add the dependency to your Cargo.toml.

[dependencies]
feed-rs = "2.3.1"

To automatically sanitize parsed HTML content, use the sanitize feature. Note that fields with a media type of text/plain will not be sanitized, to avoid potential data loss and should be sanitized by the consumer of the feed if rendered as HTML.

[dependencies]
feed-rs = { version = "2.2.1", features = ["sanitize"] }

Reading

A feed can be parsed from any object that implements the Read trait.

use feed_rs::parser;
let xml = r#"
<feed>
   <title type="text">sample feed</title>
   <updated>2005-07-31T12:29:29Z</updated>
   <id>feed1</id>
   <entry>
       <title>sample entry</title>
       <id>entry1</id>
   </entry>
</feed>
"#;
let feed = parser::parse(xml.as_bytes()).unwrap();

The parser will automatically detect XML vs. JSON so parsing JSON Feed content works the same way.

use feed_rs::parser;
let json = r#"
{
  "version": "https://jsonfeed.org/version/1",
  "title": "JSON Feed",
  "description": "JSON Feed is a pragmatic syndication format for blogs, microblog  s, and other time-based content.",
  "home_page_url": "https://jsonfeed.org/",
  "feed_url": "https://jsonfeed.org/feed.json",
  "author": {
    "name": "Brent Simmons and Manton Reece",
    "url": "https://jsonfeed.org/"
  },
  "items": [
    {
      "title": "Announcing JSON Feed",
      "date_published": "2017-05-17T08:02:12-07:00",
      "id": "https://jsonfeed.org/2017/05/17/announcing_json_feed",
      "url": "https://jsonfeed.org/2017/05/17/announcing_json_feed",
      "content_html": "<p>We — Manton Reece and Brent Simmons — have noticed that JSON...</p>"
    }
  ]
}"#;
let feed = parser::parse(json.as_bytes()).unwrap();

License

MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)

Contribution

Any contribution intentionally submitted for inclusion in the work by you, shall be licensed as above, without any additional terms or conditions.

Original author

This crate was originally created by Hiroki Kumamoto. I would like to pay my respects to Kumamoto-san, and say thank you for allowing me to take over the crate and its ongoing maintenance. ありがとう ございます!

Dependencies

~10–18MB
~289K SLoC