Class: Colossus::Engine::Memory
- Inherits:
-
Object
- Object
- Colossus::Engine::Memory
show all
- Includes:
- Observable
- Defined in:
- lib/colossus/engines/memory/memory.rb,
lib/colossus/engines/memory/client_session.rb,
lib/colossus/engines/memory/client_session_store.rb
Overview
The Memory Engine is a non-distributed engine. Based on EventMachine in order to provide the ttl to disconnect clients.
Defined Under Namespace
Classes: ClientSession, ClientSessionStore
Instance Attribute Summary collapse
Instance Method Summary
collapse
Constructor Details
#initialize(ttl) ⇒ Memory
Returns a new instance of Memory.
12
13
14
15
16
17
18
|
# File 'lib/colossus/engines/memory/memory.rb', line 12
def initialize(ttl)
@client_sessions = Hash.new do |hash, key|
hash[key] = Colossus::Engine::Memory::ClientSessionStore.new
end
@ttl = ttl
@mutex = Mutex.new
end
|
Instance Attribute Details
#client_sessions ⇒ Object
Returns the value of attribute client_sessions.
9
10
11
|
# File 'lib/colossus/engines/memory/memory.rb', line 9
def client_sessions
@client_sessions
end
|
#mutex ⇒ Object
Returns the value of attribute mutex.
9
10
11
|
# File 'lib/colossus/engines/memory/memory.rb', line 9
def mutex
@mutex
end
|
#ttl ⇒ Object
Returns the value of attribute ttl.
9
10
11
|
# File 'lib/colossus/engines/memory/memory.rb', line 9
def ttl
@ttl
end
|
Instance Method Details
#delete(user_id) ⇒ Object
65
66
67
68
69
|
# File 'lib/colossus/engines/memory/memory.rb', line 65
def delete(user_id)
mutex.synchronize do
client_sessions.delete(user_id)
end
end
|
#delete_expired_users(user_ids) ⇒ Object
106
107
108
109
110
111
|
# File 'lib/colossus/engines/memory/memory.rb', line 106
def delete_expired_users(user_ids)
user_ids.each do |user_id|
delete(user_id)
user_changed(user_id, 'disconnected')
end
end
|
#gc_ttl ⇒ Object
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
# File 'lib/colossus/engines/memory/memory.rb', line 84
def gc_ttl
user_ids_to_delete = []
client_sessions.each_pair do |user_id, session_store|
sessions_dupped = session_store.sessions.dup
session_store.sessions.each_pair do |session_id, session|
if (session.last_seen + ttl) < Time.now
sessions_dupped.delete(session_id)
end
end
mutex.synchronize { session_store.sessions = sessions_dupped }
if (session_store.last_seen + ttl) < Time.now
user_ids_to_delete << user_id
end
end
delete_expired_users(user_ids_to_delete)
end
|
#get(user_id) ⇒ Object
45
46
47
48
49
50
51
|
# File 'lib/colossus/engines/memory/memory.rb', line 45
def get(user_id)
if client_sessions.has_key?(user_id)
{ user_id => client_sessions[user_id].status }
else
{ user_id => 'disconnected' }
end
end
|
#get_all ⇒ Object
57
58
59
60
61
62
63
|
# File 'lib/colossus/engines/memory/memory.rb', line 57
def get_all
statuses = {}
client_sessions.each_pair do |user_id, session_store|
statuses[user_id] = session_store.status
end
statuses
end
|
#get_multi(*user_ids) ⇒ Object
53
54
55
|
# File 'lib/colossus/engines/memory/memory.rb', line 53
def get_multi(*user_ids)
user_ids.inject({}) { |memo, user_id| memo.merge!(get(user_id)) }
end
|
#new_periodic_ttl ⇒ Object
79
80
81
82
|
# File 'lib/colossus/engines/memory/memory.rb', line 79
def new_periodic_ttl
secs_ttl = Colossus.config.seconds_before_ttl_check
@periodic_ttl = EM::Synchrony.add_periodic_timer(secs_ttl, &method(:gc_ttl))
end
|
#reset! ⇒ Object
71
72
73
74
75
76
77
|
# File 'lib/colossus/engines/memory/memory.rb', line 71
def reset!
mutex.synchronize do
@client_sessions = Hash.new do |hash, key|
hash[key] = Colossus::Engine::Memory::ClientSessionStore.new
end
end
end
|
#set(user_id, client_id, given_status) ⇒ Object
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
# File 'lib/colossus/engines/memory/memory.rb', line 25
def set(user_id, client_id, given_status)
mutex.synchronize do
if given_status == 'disconnected'
client_sessions[user_id].delete(client_id)
else
client_sessions[user_id][client_id] = given_status
end
end
if client_sessions[user_id].sessions.empty? ||
client_sessions[user_id].status_changed?
status = client_sessions[user_id].status
delete(user_id) if status == 'disconnected'
user_changed(user_id, status)
return true
end
false
end
|
#user_changed(user_id, status) ⇒ Object
20
21
22
23
|
# File 'lib/colossus/engines/memory/memory.rb', line 20
def user_changed(user_id, status)
changed
notify_observers(user_id, status)
end
|