自分用のメモも兼ねて今は亡きRSSリーダーを作ったときのノウハウを少しずつときどき書いていこうと思います。

RSSリーダーによくある機能として現在開いているページのRSSフィードを購読するというフローがあるんですが、それと同じ機能を実現しようとしたときに使用したruby gemを紹介します。

damog/feedbag

このfeedbagは渡されたURLからフィードのURLをいろいろ頑張って抽出し、URLのArrayを返すというシンプルなライブラリです。

1$ gem install feedbag

でインストールでき、

1Feedbag.find("URL")

とすれば使用できます。

ためしにこのブログのトップページのURLを渡してみます。

1$ pry
2[1] pry(main)> require 'feedbag'
3=> true
4[2] pry(main)>
5[2] pry(main)> Feedbag.find "https://blog.piyo.tech/"
6=> ["https://blog.piyo.tech/feed",
7 "https://blog.piyo.tech/rss",
8 "http://developer.hatena.ne.jp/ja/documents/bookmark/apis/atom"]

このように3つのURLを得ることができました。1つ目と2つ目が使えそうです。3つ目は関係ないURLですが、フィードだと判定されてしまったようです。

次にこのブログの個別ページのURLを渡してみます。

1[3] pry(main)> Feedbag.find "https://blog.piyo.tech/posts/2014-01-02-204306"
2=> ["https://blog.piyo.tech/feed", "https://blog.piyo.tech/rss"]

今度は2つになりましたが、トップページを渡したときに得られたうちの2つと一致しています。どちらも使えそう。

このライブラリの実装を見てみるとHTMLタグを解析していろいろ頑張ってくれているみたい。

体感的にはフィードを持つ全てのサイトで動く感じがしたので、このライブラリに任せれば良いと思います。