12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- module Ticket::Assets
- extend ActiveSupport::Concern
- =begin
- get all assets / related models for this ticket
- ticket = Ticket.find(123)
- result = ticket.assets(assets_if_exists)
- returns
- result = {
- users: {
- 123: user_model_123,
- 1234: user_model_1234,
- },
- tickets: [ ticket_model1 ]
- }
- =end
- def assets(data)
- app_model = self.class.to_app_model
- if !data[ app_model ]
- data[ app_model ] = {}
- end
- return data if data[ app_model ][ id ]
- data[ app_model ][ id ] = attributes_with_association_ids
- group.assets(data)
- organization&.assets(data)
- assets_user(data)
- data
- end
- def assets_user(data)
- app_model_user = User.to_app_model
- %w[created_by_id updated_by_id owner_id customer_id].each do |local_user_id|
- next if !self[ local_user_id ]
- next if data[ app_model_user ] && data[ app_model_user ][ self[ local_user_id ] ]
- user = User.lookup(id: self[ local_user_id ])
- next if !user
- data = user.assets(data)
- end
- end
- def authorized_asset?
- return true if UserInfo.current_user.blank?
- return true if TicketPolicy.new(UserInfo.current_user, self).show?
- false
- end
- end
|