]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/request_token.rb
Initial work on support for multiple editors
[rails.git] / app / models / request_token.rb
index 1be8c69026881513cb280230b07e674a51584fe3..0044dde261e70debd643f09996d1bafe13c61995 100644 (file)
@@ -1,19 +1,23 @@
 class RequestToken < OauthToken
 class RequestToken < OauthToken
+
+  attr_accessor :provided_oauth_verifier
+
   def authorize!(user)
     return false if authorized?
     self.user = user
     self.authorized_at = Time.now
   def authorize!(user)
     return false if authorized?
     self.user = user
     self.authorized_at = Time.now
+    self.verifier = OAuth::Helper.generate_key(16)[0,20] unless oauth10?
     self.save
   end
     self.save
   end
-  
+
   def exchange!
     return false unless authorized?
   def exchange!
     return false unless authorized?
+    return false unless oauth10? || verifier == provided_oauth_verifier
+
     RequestToken.transaction do
     RequestToken.transaction do
-      logger.info("£££ In exchange!")
       params = { :user => user, :client_application => client_application }
       # copy the permissions from the authorised request token to the access token
       params = { :user => user, :client_application => client_application }
       # copy the permissions from the authorised request token to the access token
-      client_application.permissions.each { |p| 
-        logger.info("£££ copying permission #{p} = #{read_attribute(p).inspect}")
+      client_application.permissions.each { |p|
         params[p] = read_attribute(p)
       }
 
         params[p] = read_attribute(p)
       }
 
@@ -22,4 +26,21 @@ class RequestToken < OauthToken
       access_token
     end
   end
       access_token
     end
   end
+
+  def to_query
+    if oauth10?
+      super
+    else
+      "#{super}&oauth_callback_confirmed=true"
+    end
+  end
+
+  def oob?
+    self.callback_url=='oob'
+  end
+
+  def oauth10?
+    (defined? OAUTH_10_SUPPORT) && OAUTH_10_SUPPORT && self.callback_url.blank?
+  end
+
 end
 end