Module: Singularity

Defined in:
lib/singularity.rb,
lib/singularity/profile.rb,
lib/singularity/version.rb,
lib/singularity/password_hash.rb

Defined Under Namespace

Classes: PasswordHash, Profile

Constant Summary collapse

VERSION =
"0.1.0"

Class Method Summary collapse

Class Method Details

.cattr_accessor(attribute, default = nil) ⇒ Object



6
7
8
9
10
11
12
13
14
15
16
17
# File 'lib/singularity.rb', line 6

def self.cattr_accessor(attribute, default = nil)
  class_variable_set("@@#{attribute}", default)
  class_eval <<-EOS
    def self.#{attribute}=(value)
      @@#{attribute} = value
    end

    def self.#{attribute}
      @@#{attribute}
    end
  EOS
end

.destroy_session(*ids) ⇒ Object



72
73
74
# File 'lib/singularity.rb', line 72

def destroy_session(*ids)
  redis.del( *ids.map{ |id| session_key(id) } )
end

.destroy_token(*tokens) ⇒ Object



76
77
78
# File 'lib/singularity.rb', line 76

def destroy_token(*tokens)
  redis.del( *tokens.map{ |t| token_key(t) } )
end

.fetch_key_from_session(session_id, key) ⇒ Object



64
65
66
# File 'lib/singularity.rb', line 64

def fetch_key_from_session(session_id, key)
  redis.hget session_key(session_id), key if session_id
end

.find_session_id_by_token(session_token) ⇒ Object



58
59
60
61
62
# File 'lib/singularity.rb', line 58

def find_session_id_by_token(session_token)
  session_id = redis.get token_key(session_token)
  return nil if session_id.nil?
  redis.exists(session_key(session_id)) ? session_id : nil
end

.generate_session_token(session_id, session, options = {}) ⇒ Object



28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# File 'lib/singularity.rb', line 28

def generate_session_token(session_id, session, options = {})
  if session.key?("_token_expires") && session["_token_expires"].to_i > Time.now.to_i
    unless session.nil? || session["_session_id"] != session_id
      return session["_token"]
    else
      redis.del token_key(session['_token'])
    end
  end

  session_token    = SecureRandom.hex(32)
  token_expiration = options.fetch(:expires){ redis.ttl session_key(session_id) }
  token_expiration = 1_800 if token_expiration < 1

  redis.setex token_key(session_token), token_expiration, session_id

  session["_session_id"]    = session_id
  session["_token"]         = session_token
  session["_token_expires"] = Time.now.to_i + token_expiration

  session_token
end

.redisObject



80
81
82
# File 'lib/singularity.rb', line 80

def redis
  @redis ||= Redis.current
end

.session_key(id) ⇒ Object



50
51
52
# File 'lib/singularity.rb', line 50

def session_key(id)
  Singularity.session_prefix ? "#{ Singularity.session_prefix }:#{ id }" : id
end

.store_key_in_session(session_id, key, value) ⇒ Object



68
69
70
# File 'lib/singularity.rb', line 68

def store_key_in_session(session_id, key, value)
  redis.hset session_key(session_id), key, value if session_id
end

.token_key(token) ⇒ Object



54
55
56
# File 'lib/singularity.rb', line 54

def token_key(token)
  "#{ Singularity.token_prefix }:#{ token }"
end