Module: Singularity

Extended by:
Forwardable
Defined in:
lib/singularity.rb,
lib/singularity/profile.rb,
lib/singularity/version.rb,
lib/singularity/configuration.rb,
lib/singularity/password_hash.rb

Defined Under Namespace

Classes: Configuration, PasswordHash, Profile

Constant Summary collapse

VERSION =
"0.1.1"

Class Method Summary collapse

Class Method Details

.configureObject



13
14
15
16
17
18
19
# File 'lib/singularity.rb', line 13

def configure
  if block_given?
    yield @config
  else
    @config
  end
end

.destroy_session(*ids) ⇒ Object



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

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

.destroy_token(*tokens) ⇒ Object



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

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

.fetch_key_from_session(session_id, key) ⇒ Object



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

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



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

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



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# File 'lib/singularity.rb', line 24

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



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

def redis
  @redis ||= Redis.current
end

.session_key(id) ⇒ Object



46
47
48
# File 'lib/singularity.rb', line 46

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

.store_key_in_session(session_id, key, value) ⇒ Object



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

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



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

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