trabajo-afectivo/lib/sessions/event/chat_session_start.rb

73 lines
1.7 KiB
Ruby
Raw Normal View History

class Sessions::Event::ChatSessionStart < Sessions::Event::ChatBase
2015-11-10 14:01:04 +00:00
=begin
a agent start`s a new chat session
payload
{
event: 'chat_session_start',
data: {},
}
return is sent as message back to peer
=end
def run
2015-12-09 13:09:37 +00:00
return super if super
return if !permission_check('chat.agent', 'chat')
2015-11-10 14:01:04 +00:00
# find first in waiting list
chat_user = User.lookup(id: @session['id'])
chat_ids = Chat.agent_active_chat_ids(chat_user)
chat_session = Chat::Session.where(state: 'waiting', chat_id: chat_ids).order(created_at: :asc).first
2015-11-10 14:01:04 +00:00
if !chat_session
return {
event: 'chat_session_start',
data: {
state: 'failed',
2015-11-10 14:01:04 +00:00
message: 'No session available.',
},
}
end
chat_session.user_id = chat_user.id
2015-11-10 14:01:04 +00:00
chat_session.state = 'running'
chat_session.preferences[:participants] = chat_session.add_recipient(@client_id)
2015-11-10 14:01:04 +00:00
chat_session.save
# send chat_session_init to client
user = chat_session.agent_user
2015-11-10 14:01:04 +00:00
data = {
event: 'chat_session_start',
data: {
state: 'ok',
agent: user,
2015-11-10 14:01:04 +00:00
session_id: chat_session.session_id,
chat_id: chat_session.chat_id,
2015-11-10 14:01:04 +00:00
},
}
# send to customer
chat_session.send_to_recipients(data, @client_id)
2015-11-10 14:01:04 +00:00
# send to agent
data = {
event: 'chat_session_start',
data: {
session: chat_session.attributes,
},
}
Sessions.send(@client_id, data)
# send state update with sessions to agents
Chat.broadcast_agent_state_update([chat_session.chat_id])
# send position update to other waiting sessions
Chat.broadcast_customer_state_update(chat_session.chat_id)
nil
2015-11-10 14:01:04 +00:00
end
2015-12-09 13:09:37 +00:00
2015-11-10 14:01:04 +00:00
end