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 < ApplicationRecord
39 belongs_to :client_application, :optional => true
40 belongs_to :user, :optional => true
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(:invalidated_at => Time.now.utc)
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]