Integrating Twitter and OAuth with ColdFusion

Integrating Twitter and OAuth with ColdFusion

The Goal

My goal was to integrate Twitter using ColdFusion and the OAuth protocol. Twitter has said that they want to switch over to OAuth in the future, so I want to develop my app in a way that won't be obsolete 6 months or a year down the road. Plus, I won't have to deal with the security of users' login credentials.

My first stop was the Twitter API wiki, which has a couple ColdFusion libraries for the Twitter API, but neither takes advantage of OAuth. I bet they're both great solutions, but the lack of OAuth was a deal breaker for me.

Then I found Twitter4J by Yusuke Yamamoto. It's a Java solution with OAuth support. Score!

The Authentication Process

This is where I had the most trouble. I just couldn't seem to get a straight answer on the step-by-step details for the authentication process. It's actually pretty straightforward -- if it's laid out nicely. Luckily, that's exactly what I've done here:

  1. Within the application, generate a Request Token and a Request Secret.
  2. Using Twitter's authorization URL, you send the user to Twitter's website so that the user can Allow or Deny access to your application.
  3. Presuming the user allows access, they are then redirected back to your application based upon the Callback URL you specify when registering with Twitter.
  4. Once the user is back on your site, you have to swap out the Request Tokens for Access Tokens. This is the magic step where you finally gain access to the user's Twitter account.
  5. Store the Access Tokens for future use however you'd like -- I store them in a database. They never expire, although they can be rejected in the future if the user chooses, so make sure you do your error checking.
  6. Each time you want to access the user's account, you pull out the Access Tokens and go to town.

Of course, there's a lot more that goes on behind-the-scenes, but for the scope of this write-up, that's all we really need to know.

The Solution

  1. Register your application with Twitter here and keep the Consumer Key & Secret values handy.
  2. Download Twitter4J
  3. Install the JAR file in ColdFusion. You'll want to place it in an existing Class Path (like "C:\ColdFusion8\lib\") or you can set up a new Class Path in "CF Admin > Server Settings > Java and JVM". Then restart CF.
  4. Create the Java object in your application with the Twitter values from Step 1:
     
    <cfset Twitter = createObject("java", "twitter4j.Twitter")>
    <cfset Twitter.setOAuthConsumer(TwitterConsumerKey,TwitterConsumerSecret)>
     
  5. Now we start the authentication process, which is where things get fun. First, we generate our Request tokens to send to Twitter. We have to save the Request Token and Request Secret values for later use when the user is transferred back to the application. I've chosen to do so in Session variables, but this can be accomplished however you'd prefer.
     
    <cfset RequestToken = Twitter.getOAuthRequestToken()>
    <cfset Session.oAuthRequestToken = RequestToken.getToken()>
    <cfset Session.oAuthRequestTokenSecret = RequestToken.getTokenSecret()>
    <cflocation url="#RequestToken.getAuthorizationURL()#" addtoken="No">
     
  6. At this point, the user is on Twitter's site and have the opportunity to Allow or Deny access.
  7. After Allowing access, the user is transferred back to your site and you exchange the Request Tokens for Access Tokens:
     
    <cfset AccessToken = Twitter.getOAuthAccessToken(Session.oAuthRequestToken,Session.oAuthRequestTokenSecret)>
    <!--- Store the Access Tokens, via: AccessToken.getToken() and AccessToken.getTokenSecret() --->
     
  8. Now, with Access Tokens in hand, you have full access to the account.

    Update: The Authorization process (4-7 above) is only required once per user in order to obtain the user's unique Access Tokens. Only Step 9 needs to be executed each time you want to access the account.

  9. Finally, to use your new powers, you only have to instantiate the Twitter object, load up a users Access Tokens, and then have fun with all of the methods Twitter4J offers.
     
    <cfset Twitter = createObject("java", "twitter4j.Twitter")>
    <cfset Twitter.setOAuthConsumer(TwitterConsumerKey,TwitterConsumerSecret)>
    <cfset Twitter.setOAuthAccessToken(StoredAccessToken,StoredAccessSecret)>
    <cfset Twitter.updateStatus("My first custom Twitter update! Thanks @RobOBrien!")>
     

Obviously, this only scratches the surface of what you can do with Twitter4J and how you implement the authorization process. What I've explained is a bare bones solution. I've actually wrapped it up in some CFCs and integrated it into my larger application, but that's up to your own situation and techniques.

I hope that this will help prevent the frustration that I had to endure to get this working. If you have any questions, let me know, but I can't promise any true support on this. I'm just sharing the knowledge.

Many thanks to Yusuke for all the work he's put into this library.

Have fun!

Has this solution saved you time?

I'm a firm believer in sharing knowledge for the sake of helping someone else. No strings attached. However, we all have bills to pay and hosting to maintain. If you feel like this post has saved you even an hour of development time, would you consider donating that hour to me?


Pages: 1 2

About the Author

Rob has been in web development for over 10 years, 9 of which have been focused on being a ColdFusion Application Developer. Project Management, eCommerce Consulting, and Marketing Consulting are also in the quiver. If you like what I have to say, consider following me on Twitter or reading more about me here: About Rob O'Brien