You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

members_controller.rb 3.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. # Redmine - project management software
  2. # Copyright (C) 2006-2017 Jean-Philippe Lang
  3. #
  4. # This program is free software; you can redistribute it and/or
  5. # modify it under the terms of the GNU General Public License
  6. # as published by the Free Software Foundation; either version 2
  7. # of the License, or (at your option) any later version.
  8. #
  9. # This program is distributed in the hope that it will be useful,
  10. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. # GNU General Public License for more details.
  13. #
  14. # You should have received a copy of the GNU General Public License
  15. # along with this program; if not, write to the Free Software
  16. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  17. class MembersController < ApplicationController
  18. model_object Member
  19. before_action :find_model_object, :except => [:index, :new, :create, :autocomplete]
  20. before_action :find_project_from_association, :except => [:index, :new, :create, :autocomplete]
  21. before_action :find_project_by_project_id, :only => [:index, :new, :create, :autocomplete]
  22. before_action :authorize
  23. accept_api_auth :index, :show, :create, :update, :destroy
  24. require_sudo_mode :create, :update, :destroy
  25. def index
  26. scope = @project.memberships
  27. @offset, @limit = api_offset_and_limit
  28. @member_count = scope.count
  29. @member_pages = Paginator.new @member_count, @limit, params['page']
  30. @offset ||= @member_pages.offset
  31. @members = scope.order(:id).limit(@limit).offset(@offset).to_a
  32. respond_to do |format|
  33. format.html { head 406 }
  34. format.api
  35. end
  36. end
  37. def show
  38. respond_to do |format|
  39. format.html { head 406 }
  40. format.api
  41. end
  42. end
  43. def new
  44. @member = Member.new
  45. end
  46. def create
  47. members = []
  48. if params[:membership]
  49. user_ids = Array.wrap(params[:membership][:user_id] || params[:membership][:user_ids])
  50. user_ids << nil if user_ids.empty?
  51. user_ids.each do |user_id|
  52. member = Member.new(:project => @project, :user_id => user_id)
  53. member.set_editable_role_ids(params[:membership][:role_ids])
  54. members << member
  55. end
  56. @project.members << members
  57. end
  58. respond_to do |format|
  59. format.html { redirect_to_settings_in_projects }
  60. format.js {
  61. @members = members
  62. @member = Member.new
  63. }
  64. format.api {
  65. @member = members.first
  66. if @member.valid?
  67. render :action => 'show', :status => :created, :location => membership_url(@member)
  68. else
  69. render_validation_errors(@member)
  70. end
  71. }
  72. end
  73. end
  74. def edit
  75. @roles = Role.givable.to_a
  76. end
  77. def update
  78. if params[:membership]
  79. @member.set_editable_role_ids(params[:membership][:role_ids])
  80. end
  81. saved = @member.save
  82. respond_to do |format|
  83. format.html { redirect_to_settings_in_projects }
  84. format.js
  85. format.api {
  86. if saved
  87. render_api_ok
  88. else
  89. render_validation_errors(@member)
  90. end
  91. }
  92. end
  93. end
  94. def destroy
  95. if @member.deletable?
  96. @member.destroy
  97. end
  98. respond_to do |format|
  99. format.html { redirect_to_settings_in_projects }
  100. format.js
  101. format.api {
  102. if @member.destroyed?
  103. render_api_ok
  104. else
  105. head :unprocessable_entity
  106. end
  107. }
  108. end
  109. end
  110. def autocomplete
  111. respond_to do |format|
  112. format.js
  113. end
  114. end
  115. private
  116. def redirect_to_settings_in_projects
  117. redirect_to settings_project_path(@project, :tab => 'members')
  118. end
  119. end