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
|
.redis ⇒ Object
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
|