Small improvements to pushing data.
This commit is contained in:
parent
b5671069e1
commit
3512afc5c4
1 changed files with 180 additions and 63 deletions
|
@ -101,17 +101,7 @@ puts 'push overview ' + overview.meta[:url].to_s
|
||||||
users = {}
|
users = {}
|
||||||
tickets = []
|
tickets = []
|
||||||
overview_data[:tickets].each {|ticket|
|
overview_data[:tickets].each {|ticket|
|
||||||
data = Ticket.full_data(ticket.id)
|
self.jobs_ticket( ticket.id, state_client_ids[client_id], tickets, users )
|
||||||
tickets.push data
|
|
||||||
if !users[ data['owner_id'] ]
|
|
||||||
users[ data['owner_id'] ] = User.user_data_full( data['owner_id'] )
|
|
||||||
end
|
|
||||||
if !users[ data['customer_id'] ]
|
|
||||||
users[ data['customer_id'] ] = User.user_data_full( data['customer_id'] )
|
|
||||||
end
|
|
||||||
if !users[ data['created_by_id'] ]
|
|
||||||
users[ data['created_by_id'] ] = User.user_data_full( data['created_by_id'] )
|
|
||||||
end
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# send update to browser
|
# send update to browser
|
||||||
|
@ -129,57 +119,99 @@ puts 'push overview ' + overview.meta[:url].to_s
|
||||||
}
|
}
|
||||||
|
|
||||||
# recent viewed
|
# recent viewed
|
||||||
recent_viewed = History.recent_viewed(user)
|
self.jobs_recent_viewed(
|
||||||
if state_client_ids[client_id][:recent_viewed] != recent_viewed
|
user,
|
||||||
state_client_ids[client_id][:recent_viewed] = recent_viewed
|
client_id,
|
||||||
|
state_client_ids[client_id],
|
||||||
# tickets and users
|
)
|
||||||
recent_viewed = History.recent_viewed_fulldata(user)
|
|
||||||
|
|
||||||
# send update to browser
|
|
||||||
Session.transaction( client_id, {
|
|
||||||
:data => recent_viewed,
|
|
||||||
:event => 'update_recent_viewed',
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
# activity stream
|
# activity stream
|
||||||
activity_stream = History.activity_stream(user)
|
self.jobs_activity_stream(
|
||||||
if state_client_ids[client_id][:activity_stream] != activity_stream
|
user,
|
||||||
state_client_ids[client_id][:activity_stream] = activity_stream
|
client_id,
|
||||||
|
state_client_ids[client_id],
|
||||||
activity_stream = History.activity_stream_fulldata(user)
|
)
|
||||||
|
|
||||||
# send update to browser
|
|
||||||
Session.transaction( client_id, {
|
|
||||||
:event => 'activity_stream_rebuild',
|
|
||||||
:collection => 'activity_stream',
|
|
||||||
:data => activity_stream,
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
# ticket create
|
# ticket create
|
||||||
ticket_create_attributes = Ticket.create_attributes(
|
self.jobs_create_attributes(
|
||||||
:current_user_id => user.id,
|
user,
|
||||||
|
client_id,
|
||||||
|
state_client_ids[client_id],
|
||||||
)
|
)
|
||||||
if state_client_ids[client_id][:ticket_create_attributes] != ticket_create_attributes
|
|
||||||
state_client_ids[client_id][:ticket_create_attributes] = ticket_create_attributes
|
|
||||||
|
|
||||||
# send update to browser
|
|
||||||
Session.transaction( client_id, {
|
|
||||||
:data => ticket_create_attributes,
|
|
||||||
:collection => 'ticket_create_attributes',
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
# system settings
|
# system settings
|
||||||
|
|
||||||
|
|
||||||
|
# rss view
|
||||||
|
self.jobs_rss(
|
||||||
|
user,
|
||||||
|
client_id,
|
||||||
|
state_client_ids[client_id],
|
||||||
|
'http://www.heise.de/newsticker/heise-atom.xml'
|
||||||
|
)
|
||||||
|
sleep 1
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.jobs_ticket(ticket_id, client_state, tickets, users)
|
||||||
|
|
||||||
|
puts 'check :overview'
|
||||||
|
|
||||||
|
if !client_state['tickets']
|
||||||
|
client_state['tickets'] = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
# add ticket if needed
|
||||||
|
data = Ticket.full_data(ticket_id)
|
||||||
|
if client_state['tickets'][ticket_id] != data
|
||||||
|
client_state['tickets'][ticket_id] = data
|
||||||
|
tickets.push data
|
||||||
|
end
|
||||||
|
|
||||||
|
# add users if needed
|
||||||
|
self.jobs_user( data['owner_id'], client_state, users )
|
||||||
|
self.jobs_user( data['customer_id'], client_state, users )
|
||||||
|
self.jobs_user( data['created_by_id'], client_state, users )
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.jobs_user(user_id, client_state, users)
|
||||||
|
|
||||||
|
if !client_state['users']
|
||||||
|
client_state['users'] = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
# get user
|
||||||
|
user = User.user_data_full( user_id )
|
||||||
|
|
||||||
|
# user is already on client and not changed
|
||||||
|
return if client_state['users'][ user_id ] == user
|
||||||
|
|
||||||
|
puts 'push user ... ' + user['login']
|
||||||
|
# user not on client or different
|
||||||
|
users[ user_id ] = user
|
||||||
|
client_state['users'][ user_id ] = user
|
||||||
|
end
|
||||||
|
|
||||||
# rss view
|
# rss view
|
||||||
rss_items = RSS.fetch( 'http://www.heise.de/newsticker/heise-atom.xml', 8 )
|
def self.jobs_rss(user_id, client_id, client_state, url)
|
||||||
if state_client_ids[client_id][:rss_items] != rss_items
|
|
||||||
state_client_ids[client_id][:rss_items] = rss_items
|
# name space
|
||||||
|
if !client_state[:rss_items]
|
||||||
|
client_state[:rss_items] = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
# only fetch every 5 minutes
|
||||||
|
return if client_state[:rss_items][:last_run] && Time.new - client_state[:rss_items][:last_run] < 5.minutes
|
||||||
|
|
||||||
|
# remember last run
|
||||||
|
client_state[:rss_items][:last_run] = Time.new
|
||||||
|
|
||||||
|
puts 'check :rss'
|
||||||
|
# fetch rss
|
||||||
|
rss_items = RSS.fetch( url, 8 )
|
||||||
|
if client_state[:rss_items][:data] != rss_items
|
||||||
|
client_state[:rss_items][:data] = rss_items
|
||||||
|
|
||||||
# send update to browser
|
# send update to browser
|
||||||
Session.transaction( client_id, {
|
Session.transaction( client_id, {
|
||||||
|
@ -191,8 +223,93 @@ puts 'push overview ' + overview.meta[:url].to_s
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
sleep 1
|
end
|
||||||
}
|
|
||||||
|
def self.jobs_recent_viewed(user, client_id, client_state)
|
||||||
|
|
||||||
|
# name space
|
||||||
|
if !client_state[:recent_viewed]
|
||||||
|
client_state[:recent_viewed] = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
# only fetch every x seconds
|
||||||
|
return if client_state[:recent_viewed][:last_run] && Time.new - client_state[:recent_viewed][:last_run] < 10.seconds
|
||||||
|
|
||||||
|
# remember last run
|
||||||
|
client_state[:recent_viewed][:last_run] = Time.new
|
||||||
|
|
||||||
|
puts 'check :recent_viewed'
|
||||||
|
recent_viewed = History.recent_viewed(user)
|
||||||
|
if client_state[:recent_viewed][:data] != recent_viewed
|
||||||
|
client_state[:recent_viewed][:data] = recent_viewed
|
||||||
|
|
||||||
|
# tickets and users
|
||||||
|
recent_viewed = History.recent_viewed_fulldata(user)
|
||||||
|
|
||||||
|
# send update to browser
|
||||||
|
Session.transaction( client_id, {
|
||||||
|
:data => recent_viewed,
|
||||||
|
:event => 'update_recent_viewed',
|
||||||
|
})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.jobs_activity_stream(user, client_id, client_state)
|
||||||
|
|
||||||
|
# name space
|
||||||
|
if !client_state[:activity_stream]
|
||||||
|
client_state[:activity_stream] = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
# only fetch every x seconds
|
||||||
|
return if client_state[:activity_stream][:last_run] && Time.new - client_state[:activity_stream][:last_run] < 20.seconds
|
||||||
|
|
||||||
|
# remember last run
|
||||||
|
client_state[:activity_stream][:last_run] = Time.new
|
||||||
|
|
||||||
|
puts 'check :activity_stream'
|
||||||
|
|
||||||
|
activity_stream = History.activity_stream(user)
|
||||||
|
if client_state[:activity_stream][:data] != activity_stream
|
||||||
|
client_state[:activity_stream][:data] = activity_stream
|
||||||
|
|
||||||
|
activity_stream = History.activity_stream_fulldata(user)
|
||||||
|
|
||||||
|
# send update to browser
|
||||||
|
Session.transaction( client_id, {
|
||||||
|
:event => 'activity_stream_rebuild',
|
||||||
|
:collection => 'activity_stream',
|
||||||
|
:data => activity_stream,
|
||||||
|
})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.jobs_create_attributes(user, client_id, client_state)
|
||||||
|
|
||||||
|
# name space
|
||||||
|
if !client_state[:create_attributes]
|
||||||
|
client_state[:create_attributes] = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
# only fetch every x seconds
|
||||||
|
return if client_state[:create_attributes][:last_run] && Time.new - client_state[:create_attributes][:last_run] < 15.seconds
|
||||||
|
|
||||||
|
# remember last run
|
||||||
|
client_state[:create_attributes][:last_run] = Time.new
|
||||||
|
|
||||||
|
puts 'check :create_attributes'
|
||||||
|
ticket_create_attributes = Ticket.create_attributes(
|
||||||
|
:current_user_id => user.id,
|
||||||
|
)
|
||||||
|
|
||||||
|
if client_state[:create_attributes][:data] != ticket_create_attributes
|
||||||
|
client_state[:create_attributes][:data] = ticket_create_attributes
|
||||||
|
|
||||||
|
# send update to browser
|
||||||
|
Session.transaction( client_id, {
|
||||||
|
:data => ticket_create_attributes,
|
||||||
|
:collection => 'ticket_create_attributes',
|
||||||
|
})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue