2013-06-25 08:00:20 +01:00
|
|
|
# -*- encoding : utf-8 -*-
|
|
|
|
class Token < ActiveRecord::Base
|
|
|
|
belongs_to :subject, :polymorphic => true, :touch => true
|
|
|
|
belongs_to :creator, :class_name => 'User'
|
|
|
|
belongs_to :updater, :class_name => 'User'
|
|
|
|
|
|
|
|
validates :creator_id, :subject_id, :subject_type, :presence => true
|
2013-06-26 07:57:53 +01:00
|
|
|
validates :authentication_token, :presence => true, :uniqueness => {:case_sensitive => true}
|
2013-06-25 08:00:20 +01:00
|
|
|
|
2013-06-25 14:56:39 +01:00
|
|
|
default_scope order("#{table_name}.created_at desc")
|
2013-07-02 19:13:00 +01:00
|
|
|
scope :by_active, where(:status => 'active')
|
2013-06-25 08:00:20 +01:00
|
|
|
|
2013-06-26 07:57:53 +01:00
|
|
|
before_validation :generate_token, :on => :create
|
2013-06-25 08:00:20 +01:00
|
|
|
|
|
|
|
attr_accessible :description
|
|
|
|
|
|
|
|
state_machine :status, :initial => :active do
|
|
|
|
event :block do
|
|
|
|
transition [:active, :blocked] => :blocked
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def generate_token
|
|
|
|
self.authentication_token = loop do
|
2013-06-25 09:10:45 +01:00
|
|
|
token = SecureRandom.urlsafe_base64(32)
|
2013-06-25 08:00:20 +01:00
|
|
|
break token unless Token.where(:authentication_token => token).exists?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|