X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/a770d020f9cbd6fcf2934707d08d7fe35e592b9c..f3519e97819cc5a5e2c2f9931c7d565b8e5227c8:/app/models/oauth_token.rb?ds=sidebyside diff --git a/app/models/oauth_token.rb b/app/models/oauth_token.rb index c9595e870..9a3e7de9e 100644 --- a/app/models/oauth_token.rb +++ b/app/models/oauth_token.rb @@ -2,35 +2,34 @@ class OauthToken < ActiveRecord::Base belongs_to :client_application belongs_to :user - scope :authorized, where("authorized_at IS NOT NULL and invalidated_at IS NULL") + scope :authorized, -> { where("authorized_at IS NOT NULL and invalidated_at IS NULL") } - validates_uniqueness_of :token - validates_presence_of :client_application, :token + validates :token, :presence => true, :uniqueness => true + validates :user, :associated => true + validates :client_application, :presence => true before_validation :generate_keys, :on => :create - + def invalidated? invalidated_at != nil end - + def invalidate! - update_attributes({ - :invalidated_at => Time.now - }, :without_protection => true) + update_attributes(:invalidated_at => Time.now) end - + def authorized? - authorized_at != nil && !invalidated? + !authorized_at.nil? && !invalidated? end - + def to_query "oauth_token=#{token}&oauth_token_secret=#{secret}" end - -protected - + + protected + def generate_keys - self.token = OAuth::Helper.generate_key(40)[0,40] - self.secret = OAuth::Helper.generate_key(40)[0,40] + self.token = OAuth::Helper.generate_key(40)[0, 40] + self.secret = OAuth::Helper.generate_key(40)[0, 40] end end