lib/mambanation/oauth.rb in mambanation-0.0.3 vs lib/mambanation/oauth.rb in mambanation-0.0.5

- old
+ new

@@ -2,47 +2,53 @@ class OAuth extend Forwardable def_delegators :access_token, :get, :post, :put, :delete - attr_reader :ctoken, :csecret, :consumer_options + attr_reader :ctoken, :csecret, :consumer_options, :api_endpoint, :signing_endpoint # Options - # :sign_in => true to just sign in with mambanation instead of doing oauth authorization - # (http://apiwiki.mambanation.com/Sign-in-with-MambaNation) + # :sign_in => true to just sign in with twitter instead of doing oauth authorization + # (http://apiwiki.twitter.com/Sign-in-with-Twitter) def initialize(ctoken, csecret, options={}) @ctoken, @csecret, @consumer_options = ctoken, csecret, {} + @api_endpoint = options[:api_endpoint] || 'http://api.twitter.com' + @signing_endpoint = options[:signing_endpoint] || 'http://api.twitter.com' if options[:sign_in] @consumer_options[:authorize_path] = '/oauth/authenticate' end end def consumer - @consumer ||= ::OAuth::Consumer.new(@ctoken, @csecret, {:site => 'http://api.mambanation.com'}.merge(consumer_options)) + @consumer ||= ::OAuth::Consumer.new(@ctoken, @csecret, {:site => api_endpoint}.merge(consumer_options)) end + def signing_consumer + @signing_consumer ||= ::OAuth::Consumer.new(@ctoken, @csecret, {:site => signing_endpoint, :request_endpoint => api_endpoint }.merge(consumer_options)) + end + def set_callback_url(url) clear_request_token request_token(:oauth_callback => url) end # Note: If using oauth with a web app, be sure to provide :oauth_callback. # Options: - # :oauth_callback => String, url that mambanation should redirect to + # :oauth_callback => String, url that twitter should redirect to def request_token(options={}) - @request_token ||= consumer.get_request_token(options) + @request_token ||= signing_consumer.get_request_token(options) end # For web apps use params[:oauth_verifier], for desktop apps, - # use the verifier is the pin that mambanation gives users. + # use the verifier is the pin that twitter gives users. def authorize_from_request(rtoken, rsecret, verifier_or_pin) - request_token = ::OAuth::RequestToken.new(consumer, rtoken, rsecret) + request_token = ::OAuth::RequestToken.new(signing_consumer, rtoken, rsecret) access_token = request_token.get_access_token(:oauth_verifier => verifier_or_pin) @atoken, @asecret = access_token.token, access_token.secret end def access_token - @access_token ||= ::OAuth::AccessToken.new(consumer, @atoken, @asecret) + @access_token ||= ::OAuth::AccessToken.new(signing_consumer, @atoken, @asecret) end def authorize_from_access(atoken, asecret) @atoken, @asecret = atoken, asecret end