Skip to content

Latest commit

 

History

History
87 lines (73 loc) · 3.73 KB

README.md

File metadata and controls

87 lines (73 loc) · 3.73 KB

TwitteRSS

A server that fetches a Twitter user's home timeline and creates RSS feeds from it, a separate feed per followed user.

Example Feeds

ARCHIVED After nearly 4 years, this project has been shutdown on 2023-05-31, and will no longer be maintained because Twitter stopped supporting its v1 API. Porting to Twitter's v2 API is technically doable, but the API's free tier is too restrictive and the basic tier too expensive for a fun application such as this.

Setup

  1. Clone or download the code.
  2. Update the configuration in TwitteRSS/twitterss/config.py per your requirements. Especially pay attention to FEED_ROOT_URL and CREDENTIALS. For the latter, also refer Security and setup your Twitter API credentials.
  3. Run the following commands from a terminal:
    1. cd TwitteRSS
    2. tox -e py39
    3. source .tox/py39/bin/activate
    4. ./twitterss/twitterss.py
  4. Open feeds/twitterss.html in a browser.

NOTE: I tested this using Python v3.9.x and host this on my website using Python v3.8.x, but I suspect it will work fine for any Python that can install the requirements with trivial changes.

Design

The server runs two threads:

  1. A thread that uses python-twitter to periodically retrieve tweets from Twitter, and stores their raw JSONs in a SQLite DB.
  2. A thread that periodically retrieves un-processed tweets from the DB and updates the corresponding RSS feeds.

The intermediate storage is not necessary, but useful to be able to update the RSS feed logic without making additional Twitter API calls.

vs TwitRSS.me

TwitRSS.me is a nice and popular alternative to this application. It creates Twitter user/search feeds by scraping their web pages. Its main advantage is that it is a service readily usable by anyone.

It has a few disadvantages:

  • Case-sensitive usernames, e.g. @MattYglesias and not @mattyglesias.
  • So-so support for media and metadata.
  • Brittle to major UI changes.

By using the Twitter API, TwitteRSS overcomes all 3 disadvantages, but has other disadvantages:

  • It cannot unwind URLs and show the corresponding image, headline, and snippet. See this python-twitter issue to learn more.
  • It cannot display polls, because Twitter provides these only in its enterprise APIs.
  • It is not available as a service.
  • It uses the application's home timeline instead of user timelines. So getting the RSS feed of a new user involves following a new user.

The latter two disadvantages can be resolved without much effort, but this project was meant as a POC for my personal usage, so I am not in a hurry to make those changes. Opening up access also involves a lot of maintenance effort which I am not excited about. In the meantime, open a GitHub issue or contact me directly to request the feed URL of your choice.

Security

When creating credentials for your Twitter App make sure to get read-only access.

Save the credentials locally in a JSON like:

{
    "consumer_key": "YOUR_CONSUMER_KEY",
    "consumer_secret": "YOUR_CONSUMER_SECRET",
    "access_token_key": "YOUR_ACCESS_TOKEN_KEY",
    "access_token_secret": "YOUR_ACCESS_TOKEN_SECRET"
}

Remember to not commit/upload these credentials anywhere.

TODO

  • Switch to GET statuses/user_timeline.
  • Add a "register timeline" page and open up access.
  • Fix bear/python-twitter#484, and stop using Status._json.
  • Switch to lxml instead of hacky hand-rolled RSS feeds.