trabajo-afectivo/lib/sessions/backend/ticket_overview_list.rb

137 lines
3.4 KiB
Ruby
Raw Normal View History

2014-07-13 18:52:32 +00:00
class Sessions::Backend::TicketOverviewList
def initialize( user, client = nil, client_id = nil, ttl = 6 )
@user = user
@client = client
@client_id = client_id
@ttl = ttl
@last_change = nil
@last_ticket_change = nil
2014-07-13 18:52:32 +00:00
end
def load
2014-07-13 18:52:32 +00:00
# get whole collection
overviews = Ticket::Overviews.all(
current_user: @user,
)
result = []
overviews.each { |overview|
overview_data = Ticket::Overviews.list(
view: overview.link,
current_user: @user,
array: true,
)
data = { list: overview_data, index: overview }
result.push data
}
2015-05-04 19:45:48 +00:00
Rails.logger.debug "LOG A #{result.inspect}"
2014-07-13 18:52:32 +00:00
# no data exists
return if !result || result.empty?
2014-07-13 18:52:32 +00:00
# no change exists
return if @last_change == result
2015-05-04 19:45:48 +00:00
Rails.logger.debug "LOG B #{result.inspect}"
2014-07-13 18:52:32 +00:00
# remember last state
@last_change = result
2014-07-13 18:52:32 +00:00
result
end
2014-07-13 18:52:32 +00:00
def client_key
"as::load::#{ self.class }::#{ @user.id }::#{ @client_id }"
2014-07-13 18:52:32 +00:00
end
def push
# check interval
2015-05-04 19:45:48 +00:00
Rails.logger.debug "LOG 1 #{@user.inspect}"
2015-02-25 21:35:37 +00:00
return if Sessions::CacheIn.get( self.client_key )
2014-07-13 18:52:32 +00:00
# reset check interval
2015-05-04 19:45:48 +00:00
Rails.logger.debug "LOG 2 #{@ttl.seconds}"
Sessions::CacheIn.set( self.client_key, true, { expires_in: @ttl.seconds } )
2014-07-13 18:52:32 +00:00
# check if min one ticket has changed
last_ticket_change = Ticket.latest_change
2015-05-04 19:45:48 +00:00
Rails.logger.debug "LOG 3 #{last_ticket_change}/#{@last_ticket_change}"
return if last_ticket_change == @last_ticket_change
@last_ticket_change = last_ticket_change
# load current data
items = self.load
2015-05-04 19:45:48 +00:00
Rails.logger.debug "LOG 4 #{items.inspect}"
return if !items
2014-07-13 18:52:32 +00:00
# push overviews
results = []
items.each { |item|
overview_data = item[:list]
2014-07-13 18:52:32 +00:00
assets = {}
overview_data[:ticket_ids].each {|ticket_id|
ticket = Ticket.find( ticket_id )
assets = ticket.assets(assets)
}
2014-07-13 18:52:32 +00:00
# get groups
group_ids = []
Group.where( active: true ).each { |group|
2014-07-13 18:52:32 +00:00
group_ids.push group.id
}
agents = {}
Ticket::ScreenOptions.agents.each { |user|
agents[ user.id ] = 1
}
users = {}
groups_users = {}
groups_users[''] = []
group_ids.each {|group_id|
groups_users[ group_id ] = []
Group.find(group_id).users.each {|user|
next if !agents[ user.id ]
groups_users[ group_id ].push user.id
if !users[user.id]
users[user.id] = User.find(user.id)
assets = users[user.id].assets(assets)
end
}
2014-07-13 18:52:32 +00:00
}
if !@client
result = {
event: 'navupdate_ticket_overview',
data: item[:index],
}
results.push result
else
2015-05-04 19:45:48 +00:00
@client.log "push overview_list for user #{ @user.id }"
# send update to browser
2015-04-27 15:21:17 +00:00
@client.send(
data: assets,
event: [ 'loadAssets' ]
2015-04-27 15:21:17 +00:00
)
@client.send(
data: {
view: item[:index].link.to_s,
overview: overview_data[:overview],
ticket_ids: overview_data[:ticket_ids],
tickets_count: overview_data[:tickets_count],
bulk: {
group_id__owner_id: groups_users,
owner_id: [],
},
},
event: [ 'ticket_overview_rebuild' ],
2015-04-27 15:21:17 +00:00
)
end
}
return results if !@client
nil
end
end