I think Twitter's OAuth-only Access is a Waste of Time

I don't normally write sensationalist articles, but today I'm going depart from the norm and make a bold claim: I think Twitter's change to OAuth-only authentication is a waste of time for developers and businesses.

Don't get me wrong, I think the OAuth spec is slick and has very good intentions at it's core. Nor am I knocking it out of inexperience, as I've been building OAuth based applications for the past 6 months. However my primary gripe with Twitter's OAuth-only stance boils down to xAuth.

For those of you that aren't familiar with Twitter's recent change, before September 1st you could access their API by passing across your twitter username and password. This was fine if you were using your own credentials, however the Twitter ecosystem is rather large, and most people who interact with Twitter do it via a 3rd party service. The security issue is handing your password to an untrusted source. As of September 1st however, developers are only allowed to access the API using OAuth, which requires you to give your username and password only to Twitter and then Twitter will authorize the application on your behalf. Even I admit, the protocol is rather elegant. When it comes to Web applications, I can hardly argue the security. The user is already in a browser and being directed to Twitter and back mostly only fires up User Experience guys.

However, I have a huge issue with xAuth. xAuth is Twitter's solution to applications that have a large number of passwords already stored and allows the developers to convert them to OAuth-friendly keys behind the scenes. Well, from what I gather, that was the intended purpose. However there are many mobile Twitter applications out there only are using xAuth. Why does this tick me off?

1) As a user, I'm still giving my password to the application. The application is not supposed to store the credentials, however this is un-enforceable. At this point I'm only safe-guarded against applications that have their passwords stolen. I won't deny that's an issue, but not enough to force all developers to go OAuth-only.

2) Even Twitter's official client requires me to hand over my password. If Twitter is going to take the stance that all API usage is going to go through OAuth, I think they should eat their own dog food and redirect me to a mobile browser.

Do I dislike OAuth? Certainly not. And I know Twitter has some brilliant talent. But if Twitter is going to make OAuth vs Basic Auth this big of a priority, I think they are missing mark by moving a lot of applications to xAuth.

--

You can also discuss this further on Hacker News