Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/umurgdk/elixir-feedme

Elixir RSS/Atom parser
https://github.com/umurgdk/elixir-feedme

Last synced: 2 months ago
JSON representation

Elixir RSS/Atom parser

Awesome Lists containing this project

README

        

Feedme
======
[![Build Status](https://travis-ci.org/umurgdk/elixir-feedme.svg?branch=master)](https://travis-ci.org/umurgdk/elixir-feedme)

Elixir RSS/Atom parser built on erlang's **xmerl** xml parser. It uses [timex](https://github.com/bitwalker/timex) for parsing dates.

## Setup

Add **feedme** into your mix dependencies and applications:

```elixir
def application do
[applications: [:feedme]]
end

defp deps do
[{:feedme, "~> 0.0.1"}]
end
```
Then run ```mix deps.get``` to install feedme.

## Parsing

Feedme expose only one function named ```parse/1```. Parse function detects the feed format as **rss** or **atom**.

```elixir
{:ok, xml_string} = File.read("some.xml")
{:ok, feed} = Feedme.parse(xml_string)

# Feed
%Feedme.Feed{
meta: %Feedme.MetaData{
author: nil,
category: nil,
cloud: nil,
copyright: nil,
description: "software is fun",
docs: nil,
generator: "Ghost 0.6",
image: nil,
language: nil,
last_build_date: %Timex.DateTime{...},
link: "http://blog.drewolson.org/", managing_editor: nil,
publication_date: nil,
rating: nil,
skip_days: [],
skip_hours: [],
title: "collect {thoughts}",
ttl: "60",
web_master: nil
}
entries: [
%Feedme.Entry{
author: nil,
categories: ["elixir"],
comments: nil,
description: "

I previously wrote about explicitness in Elixir. One of my favorite ways the language embraces explicitness is in its distinction between eager and lazy operations on collections. Any time you use the Enum module, you're performing an eager operation. Your collection will be transformed/mapped/enumerated immediately. When you use

",
enclosure: %Feedme.Enclosure{
length: "12216320",
type: "audio/mpeg",
url: "http://www.tutorialspoint.com/mp3s/tutorial.mp3"
},
guid: "9b68a5a7-4ab0-420e-8105-0462357fa1f1",
link: "http://blog.drewolson.org/elixir-streams/",
publication_date: %Timex.DateTime{...},
source: nil, title: "Elixir Streams"
}
]
}
```

## ToDo

- [ ] Rss+Atom parser
- [ ] FeedBurner support