1 # == Schema Information
 
   3 # Table name: oauth_tokens
 
   5 #  id                    :integer          not null, primary key
 
   8 #  client_application_id :integer
 
  11 #  authorized_at         :datetime
 
  12 #  invalidated_at        :datetime
 
  13 #  created_at            :datetime
 
  14 #  updated_at            :datetime
 
  15 #  allow_read_prefs      :boolean          default(FALSE), not null
 
  16 #  allow_write_prefs     :boolean          default(FALSE), not null
 
  17 #  allow_write_diary     :boolean          default(FALSE), not null
 
  18 #  allow_write_api       :boolean          default(FALSE), not null
 
  19 #  allow_read_gpx        :boolean          default(FALSE), not null
 
  20 #  allow_write_gpx       :boolean          default(FALSE), not null
 
  21 #  callback_url          :string
 
  22 #  verifier              :string(20)
 
  25 #  allow_write_notes     :boolean          default(FALSE), not null
 
  29 #  index_oauth_tokens_on_token    (token) UNIQUE
 
  30 #  index_oauth_tokens_on_user_id  (user_id)
 
  34 #  oauth_tokens_client_application_id_fkey  (client_application_id => client_applications.id)
 
  35 #  oauth_tokens_user_id_fkey                (user_id => users.id)
 
  38 class OauthToken < ActiveRecord::Base
 
  39   belongs_to :client_application
 
  42   scope :authorized, -> { where("authorized_at IS NOT NULL and invalidated_at IS NULL") }
 
  44   validates :token, :presence => true, :uniqueness => true
 
  45   validates :user, :associated => true
 
  46   validates :client_application, :presence => true
 
  48   before_validation :generate_keys, :on => :create
 
  55     update_attributes(:invalidated_at => Time.now)
 
  59     !authorized_at.nil? && !invalidated?
 
  63     "oauth_token=#{token}&oauth_token_secret=#{secret}"
 
  69     self.token = OAuth::Helper.generate_key(40)[0, 40]
 
  70     self.secret = OAuth::Helper.generate_key(40)[0, 40]