trabajo-afectivo/app/models/activity_stream.rb

145 lines
3.8 KiB
Ruby
Raw Normal View History

2016-10-19 03:11:36 +00:00
# Copyright (C) 2012-2016 Zammad Foundation, http://zammad-foundation.org/
2013-09-28 00:07:11 +00:00
class ActivityStream < ApplicationModel
include ActivityStream::Assets
2013-09-28 00:07:11 +00:00
self.table_name = 'activity_streams'
2018-04-12 14:57:37 +00:00
# rubocop:disable Rails/InverseOf
belongs_to :object, class_name: 'ObjectLookup', foreign_key: 'activity_stream_object_id', optional: true
belongs_to :type, class_name: 'TypeLookup', foreign_key: 'activity_stream_type_id', optional: true
2018-04-12 14:57:37 +00:00
# rubocop:enable Rails/InverseOf
# the noop is needed since Layout/EmptyLines detects
# the block commend below wrongly as the measurement of
# the wanted indentation of the rubocop re-enabling above
def noop; end
2013-09-28 00:07:11 +00:00
=begin
add a new activity entry for an object
ActivityStream.add(
2016-02-22 19:58:23 +00:00
type: 'update',
object: 'Ticket',
permission: 'admin.user',
2016-02-22 19:58:23 +00:00
o_id: ticket.id,
created_by_id: 1,
created_at: '2013-06-04 10:00:00',
2013-09-28 00:07:11 +00:00
)
=end
def self.add(data)
# lookups
if data[:type]
2016-02-22 19:58:23 +00:00
type_id = TypeLookup.by_name(data[:type])
2013-09-28 00:07:11 +00:00
end
if data[:object]
2016-02-22 19:58:23 +00:00
object_id = ObjectLookup.by_name(data[:object])
2013-09-28 00:07:11 +00:00
end
permission_id = nil
if data[:permission]
permission = Permission.lookup(name: data[:permission])
if !permission
raise "No such Permission #{data[:permission]}"
2013-09-28 00:07:11 +00:00
end
permission_id = permission.id
2013-09-28 00:07:11 +00:00
end
# check if object for online notification exists
exists_by_object_and_id?(data[:object], data[:o_id])
# check newest entry - is needed
2013-09-28 00:07:11 +00:00
result = ActivityStream.where(
o_id: data[:o_id],
2014-12-31 14:07:56 +00:00
#:activity_stream_type_id => type_id,
permission_id: permission_id,
activity_stream_object_id: object_id,
created_by_id: data[:created_by_id]
).order(created_at: :desc).first
2013-09-28 00:07:11 +00:00
# return if old entry is really fresh
if result
activity_record_delay = 90.seconds
return result if result.created_at.to_i >= ( data[:created_at].to_i - activity_record_delay )
end
2014-06-01 08:31:04 +00:00
2013-09-28 00:07:11 +00:00
# create history
record = {
o_id: data[:o_id],
activity_stream_type_id: type_id,
activity_stream_object_id: object_id,
permission_id: permission_id,
group_id: data[:group_id],
created_at: data[:created_at],
created_by_id: data[:created_by_id]
2013-09-28 00:07:11 +00:00
}
2013-09-29 21:37:49 +00:00
2013-09-28 00:07:11 +00:00
ActivityStream.create(record)
end
=begin
remove whole activity entries of an object
2016-02-22 19:58:23 +00:00
ActivityStream.remove('Ticket', 123)
2013-09-28 00:07:11 +00:00
=end
2016-02-22 19:58:23 +00:00
def self.remove(object_name, o_id)
object_id = ObjectLookup.by_name(object_name)
2013-09-28 00:07:11 +00:00
ActivityStream.where(
activity_stream_object_id: object_id,
o_id: o_id,
2013-09-28 00:07:11 +00:00
).destroy_all
end
=begin
return all activity entries of an user
activity_stream = ActivityStream.list(user, limit)
2013-09-28 00:07:11 +00:00
=end
2015-04-27 14:53:29 +00:00
def self.list(user, limit)
# do not return an activity stream for customers
return [] if !user.permissions?('ticket.agent') && !user.permissions?('admin')
permission_ids = user.permissions_with_child_ids
group_ids = user.group_ids_access('read')
2013-09-29 21:37:49 +00:00
if group_ids.blank?
ActivityStream.where('(permission_id IN (?) AND group_id IS NULL)', permission_ids)
.order(created_at: :desc)
.limit(limit)
else
ActivityStream.where('(permission_id IN (?) AND (group_id IS NULL OR group_id IN (?))) OR (permission_id IS NULL AND group_id IN (?))', permission_ids, group_ids, group_ids)
.order(created_at: :desc)
.limit(limit)
end
2013-09-28 00:07:11 +00:00
end
2015-06-30 22:25:05 +00:00
=begin
cleanup old stream messages
ActivityStream.cleanup
optional you can put the max oldest stream entries as argument
2015-06-30 22:25:05 +00:00
ActivityStream.cleanup(3.months)
2015-06-30 22:25:05 +00:00
=end
def self.cleanup(diff = 3.months)
2015-06-30 22:25:05 +00:00
ActivityStream.where('created_at < ?', Time.zone.now - diff).delete_all
true
end
end