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