accounts_controller.rb 874 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. # frozen_string_literal: true
  2. class Api::V2::Admin::AccountsController < Api::V1::Admin::AccountsController
  3. FILTER_PARAMS = %i(
  4. origin
  5. status
  6. permissions
  7. username
  8. by_domain
  9. display_name
  10. email
  11. ip
  12. invited_by
  13. role_ids
  14. ).freeze
  15. PAGINATION_PARAMS = (%i(limit) + FILTER_PARAMS).freeze
  16. private
  17. def filtered_accounts
  18. AccountFilter.new(translated_filter_params).results
  19. end
  20. def translated_filter_params
  21. translated_params = filter_params.slice(*AccountFilter::KEYS)
  22. if params[:permissions] == 'staff'
  23. translated_params[:role_ids] = UserRole.that_can(:manage_reports).map(&:id)
  24. end
  25. translated_params
  26. end
  27. def filter_params
  28. params.permit(*FILTER_PARAMS)
  29. end
  30. def pagination_params(core_params)
  31. params.slice(*PAGINATION_PARAMS).permit(*PAGINATION_PARAMS).merge(core_params)
  32. end
  33. end