diff options
author | jessib <jessib@riseup.net> | 2013-11-12 09:16:45 -0800 |
---|---|---|
committer | jessib <jessib@riseup.net> | 2013-11-12 09:16:45 -0800 |
commit | 8295db1a8cf334ff8666e5ec29455c199c7ffc73 (patch) | |
tree | c74e801c31a8d58b157df266550bf456934c9cfc /users/app/models | |
parent | a976436d6c022b5a1d142a931ba0bf6d27a00e9c (diff) | |
parent | a7cd2ef0877e79302f27fb175384a0cf4ded52d9 (diff) |
Merge pull request #110 from azul/feature/cleanup-expired-tokens
Feature/cleanup expired tokens
Diffstat (limited to 'users/app/models')
-rw-r--r-- | users/app/models/token.rb | 36 |
1 files changed, 25 insertions, 11 deletions
diff --git a/users/app/models/token.rb b/users/app/models/token.rb index dd87344..001eb40 100644 --- a/users/app/models/token.rb +++ b/users/app/models/token.rb @@ -11,6 +11,25 @@ class Token < CouchRest::Model::Base validates :user_id, presence: true + design do + view :by_last_seen_at + end + + def self.expires_after + APP_CONFIG[:auth] && APP_CONFIG[:auth][:token_expires_after] + end + + def self.expired + return [] unless expires_after + by_last_seen_at.endkey(expires_after.minutes.ago) + end + + def self.destroy_all_expired + self.expired.each do |token| + token.destroy + end + end + def authenticate if expired? destroy @@ -27,21 +46,16 @@ class Token < CouchRest::Model::Base end def expired? - expires_after and - last_seen_at + expires_after.minutes < Time.now - end - - def expires_after - APP_CONFIG[:auth] && APP_CONFIG[:auth][:token_expires_after] + Token.expires_after and + last_seen_at < Token.expires_after.minutes.ago end def initialize(*args) super - self.id = SecureRandom.urlsafe_base64(32).gsub(/^_*/, '') - self.last_seen_at = Time.now - end - - design do + if new_record? + self.id = SecureRandom.urlsafe_base64(32).gsub(/^_*/, '') + self.last_seen_at = Time.now + end end end |