123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- class CoreWorkflow::Attributes::User < CoreWorkflow::Attributes::Base
- def values
- if @attribute[:name] == 'owner_id' && @attributes.payload['class_name'] == 'Ticket'
- return ticket_owner_id_bulk if @attributes.payload['screen'] == 'overview_bulk'
- return ticket_owner_id
- end
- []
- end
- def group_agent_user_ids(group_id)
- @group_agent_user_ids ||= {}
- @group_agent_user_ids[group_id] ||= User.joins(', groups_users').where("users.id = groups_users.user_id AND groups_users.access = 'full' AND groups_users.group_id = ? AND users.id IN (?)", group_id, agent_user_ids).pluck(:id)
- end
- def group_agent_roles_ids(group_id)
- @group_agent_roles_ids ||= {}
- @group_agent_roles_ids[group_id] ||= Role.joins(', roles_groups').where("roles.id = roles_groups.role_id AND roles_groups.access = 'full' AND roles_groups.group_id = ? AND roles.id IN (?)", group_id, agent_role_ids).pluck(:id)
- end
- def agent_user_ids
- @agent_user_ids ||= User.joins(:roles).where(users: { active: true }).where('roles_users.role_id' => agent_role_ids).pluck(:id)
- end
- def agent_role_ids
- @agent_role_ids ||= Role.with_permissions('ticket.agent').pluck(:id)
- end
- def group_agent_role_user_ids(group_id)
- @group_agent_role_user_ids ||= {}
- @group_agent_role_user_ids[group_id] ||= User.joins(:roles).where(roles: { id: group_agent_roles_ids(group_id) }).pluck(:id)
- end
- def ticket_owner_id
- return [''] if @attributes.selected_only.group_id.blank?
- owner_ids = group_owner_ids
- return [''] if owner_ids.blank?
- owner_ids
- end
- def group_owner_ids
- user_ids = []
- # dont show system user in frontend but allow to reset it to 1 on update/create of the ticket
- if @attributes.payload['request_id'] == 'ChecksCoreWorkflow.validate_workflows'
- user_ids = [1]
- end
- User.where(id: group_owner_ids_user_ids, active: true).each do |user|
- user_ids << user.id
- assets(user)
- end
- user_ids
- end
- def group_owner_ids_user_ids
- group_agent_user_ids(@attributes.selected.group_id).concat(group_agent_role_user_ids(@attributes.selected.group_id)).uniq
- end
- def group_ids_bulk
- @group_ids_bulk ||= begin
- ticket_ids = String(@attributes.payload['params']['ticket_ids']).split(',').map(&:to_i)
- Ticket.distinct.where(id: ticket_ids).pluck(:group_id)
- end
- end
- def group_users_bulk
- @group_users_bulk ||= begin
- group_users_bulk_user_count.keys.select { |user| group_users_bulk_user_count[user] == group_ids_bulk.count }
- end
- end
- def group_users_bulk_user_count
- @group_users_bulk_user_count ||= begin
- user_count = {}
- group_ids_bulk.each do |group_id|
- User.where(id: group_agent_user_ids(group_id).concat(group_agent_role_user_ids(group_id)).uniq, active: true).each do |user|
- user_count[user] ||= 0
- user_count[user] += 1
- end
- end
- user_count
- end
- end
- def ticket_owner_id_bulk
- return group_owner_ids if @attributes.selected.group_id.present?
- return [''] if group_users_bulk.blank?
- group_users_bulk.each { |user| assets(user) }
- group_users_bulk.map(&:id)
- end
- def assets(user)
- return if @attributes.assets == false
- return if @attributes.assets[User.to_app_model] && @attributes.assets[User.to_app_model][user.id]
- @attributes.assets = user.assets(@attributes.assets)
- end
- end
|