Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

twin

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

twin

  • 0.1.3
  • Rubygems
  • Socket score

Version published
Maintainers
1
Created
Source

Twitter's Twin

Twin is a Rack middleware which provides your app with a subset of Twitter's API. In other words, it makes your app respond to certain requests as if it were "api.twitter.com".

This is useful in combination with Twitter clients which allow you to change the hostname used for API requests. If your Twitter client allows you to configure it to fetch updates from "yourapp.net" instead of "api.twitter.com", you could serve fake "tweets" from your app and use the Twitter client to read them.

Twitter for iPhone is a free client that allows you to customize the hostname. (Its version for iPad does not, for some reason.) Known desktop clients that support the same are Twitterrific and Spaz.

Two popular websites which already implement the Twitter API are WordPress.com and Tumblr. Twin is a library for Ruby apps to do the same.

Installation

For Ruby on Rails, add "twin" to your Gemfile. For other apps, a little bit more is needed:

## Gemfile for non-Rails apps
gem 'twin'
gem 'i18n'    # not really used; needed to load some part of Active Support
gem 'builder' # used for constructing XML responses

Twin's dependency is Active Support, from which only few bits are loaded.

Now, mount "Twin" as middleware:

## Ruby on Rails
config.middleware.use Twin

## Sinatra
use Twin

Data models

Twin uses a model named by default "TwinAdapter" to fetch records from your app. You have to write this model yourself and implement several methods to define which data sent back to the client.

The template for TwinAdapter is available in "example/twin_adapter.rb".

The adapter should return two types of records: one representing twitter "statuses" and the other representing users. Both types of records should either be hashes containing twitter-compatible keys or they should implement the to_twin_hash method that returns such values.

Examples for implementing to_twin_hash for typical Active Record models is in "example/to_twin_hash.rb".

Configuring Twitter for iPhone

With Twin middleware and data models in place, your app is ready to receive requests from Twitter clients. To try this out with Twitter for iPhone, go to the "Accounts" page and start creating a new account. Before submitting the username and password, tap the cogwheel to access the advanced configuration screen. Type in your hostname for "API root", return back and finish the process.

Advanced configuration screen displaying "http://example.com"

Using Twitter for iPhone in this manner may not be without bugs. This client caches user info based on screen name, regardless of the host where they come from. If a user from your Twin-enabled app shares the same screen name as an existing Twitter user, their info (and avatar pictures) might mix.

API support

Twin doesn't implement the full Twitter API — far from it. It only implements the basic subset required to read the main timeline. Posting is not yet implemented. Replies/mentions, lists, saved searches and direct messages are not functional; their read APIs are implemented but they return empty collections. There is no rate limiting.

To see which APIs are implemented, check out "twin/resources.rb".

Credits

Twin was written by Mislav Marohnić for Teambox and later extracted into a reusable library after a gentle nudge by Shane Becker.

FAQs

Package last updated on 06 Nov 2011

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc