assets.rb 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. # Copyright (C) 2012-2022 Zammad Foundation, https://zammad-foundation.org/
  2. class Organization
  3. module Assets
  4. extend ActiveSupport::Concern
  5. =begin
  6. get all assets / related models for this organization
  7. organization = Organization.find(123)
  8. result = organization.assets(assets_if_exists)
  9. returns
  10. result = {
  11. :organizations => {
  12. 123 => organization_model_123,
  13. 1234 => organization_model_1234,
  14. }
  15. }
  16. =end
  17. def assets(data)
  18. app_model_organization = Organization.to_app_model
  19. if !data[ app_model_organization ]
  20. data[ app_model_organization ] = {}
  21. end
  22. return data if data[ app_model_organization ][ id ]
  23. local_attributes = attributes_with_association_ids
  24. # set temp. current attributes to assets pool to prevent
  25. # loops, will be updated with lookup attributes later
  26. data[ app_model_organization ][ id ] = local_attributes
  27. app_model_user = User.to_app_model
  28. if local_attributes['member_ids'].present?
  29. # only provide assets for the first 10 organization users
  30. # rest will be loaded optionally by the frontend
  31. local_attributes['member_ids'] = local_attributes['member_ids'].sort
  32. local_attributes['member_ids'][0, 10].each do |local_user_id|
  33. next if data[ app_model_user ] && data[ app_model_user ][ local_user_id ]
  34. user = User.lookup(id: local_user_id)
  35. next if !user
  36. data = user.assets(data)
  37. end
  38. end
  39. data[ app_model_organization ][ id ] = local_attributes
  40. if !data[ app_model_user ]
  41. data[ app_model_user ] = {}
  42. end
  43. %w[created_by_id updated_by_id].each do |local_user_id|
  44. next if !self[ local_user_id ]
  45. next if data[ app_model_user ][ self[ local_user_id ] ]
  46. user = User.lookup(id: self[ local_user_id ])
  47. next if !user
  48. data = user.assets(data)
  49. end
  50. data
  51. end
  52. def filter_unauthorized_attributes(attributes)
  53. return super if UserInfo.assets.blank? || UserInfo.assets.agent?
  54. attributes = super
  55. attributes.slice('id', 'name', 'active')
  56. end
  57. end
  58. end