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.
		
		
		
		
		
			
		
			
				
					
					
						
							363 lines
						
					
					
						
							13 KiB
						
					
					
				
			
		
		
	
	
							363 lines
						
					
					
						
							13 KiB
						
					
					
				| # -*coding:utf-8 -*-
 | |
| # Redmine - project management software
 | |
| # Copyright (C) 2006-2013  Jean-Philippe Lang
 | |
| #
 | |
| # This program is free software; you can redistribute it and/or
 | |
| # modify it under the terms of the GNU General Public License
 | |
| # as published by the Free Software Foundation; either version 2
 | |
| # of the License, or (at your option) any later version.
 | |
| #
 | |
| # This program is distributed in the hope that it will be useful,
 | |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| # GNU General Public License for more details.
 | |
| #
 | |
| # You should have received a copy of the GNU General Public License
 | |
| # along with this program; if not, write to the Free Software
 | |
| # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 | |
| 
 | |
| class MembersController < ApplicationController
 | |
|   model_object Member
 | |
|   before_filter :find_model_object, :except => [:index, :create, :autocomplete]
 | |
|   #before_filter :find_model_object_contest, :except => [:index, :create, :autocomplete]
 | |
|   before_filter :find_project_from_association, :except => [:index, :create, :autocomplete]
 | |
|   before_filter :find_project_by_project_id, :only => [:index, :create, :autocomplete]
 | |
|   before_filter :authorize
 | |
|   accept_api_auth :index, :show, :create, :update, :destroy
 | |
| 
 | |
|   def index
 | |
|     @offset, @limit = api_offset_and_limit
 | |
|     @member_count = @project.member_principals.count
 | |
|     @member_pages = Paginator.new @member_count, @limit, params['page']
 | |
|     @offset ||= @member_pages.offset
 | |
|     @members = @project.member_principals.all(
 | |
|         :order => "#{Member.table_name}.id",
 | |
|         :limit => @limit,
 | |
|         :offset => @offset
 | |
|     )
 | |
| 
 | |
|     respond_to do |format|
 | |
|       format.html { head 406 }
 | |
|       format.api
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def show
 | |
|     respond_to do |format|
 | |
|       format.html { head 406 }
 | |
|       format.api
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def create
 | |
|     if params[:refusal_button]
 | |
|       members = []
 | |
|       applied_members = true
 | |
|       if params[:membership]
 | |
|         if params[:membership][:user_ids]
 | |
|           attrs = params[:membership].dup
 | |
|           user_ids = attrs.delete(:user_ids)
 | |
|           user_ids.each do |user_id|
 | |
|             AppliedProject.deleteappiled(user_id, @project.id)
 | |
|           end
 | |
|           @succes_message = "拒绝成功"
 | |
|         end
 | |
|       end
 | |
|       respond_to do |format|
 | |
|         format.js
 | |
|       end
 | |
|     else
 | |
|       #modify by nwb
 | |
|       #更改课程成员逻辑
 | |
|       applied_members = false
 | |
|       members = []
 | |
|       user_grades = []
 | |
|       if @project
 | |
|         project_info = []
 | |
|         if params[:membership]
 | |
|           if params[:membership][:user_ids]
 | |
|             attrs = params[:membership].dup
 | |
|             user_ids = attrs.delete(:user_ids)
 | |
|             user_ids.each do |user_id|
 | |
|               members << Member.new(:role_ids => params[:membership][:role_ids], :user_id => user_id)
 | |
|               user_grades << UserGrade.new(:user_id => user_id, :project_id => @project.id)
 | |
|               ## added by nie
 | |
| 
 | |
|               if (params[:membership][:role_ids])
 | |
|                 role = Role.find(params[:membership][:role_ids][0])
 | |
|                 project_info << ProjectInfo.new(:user_id => user_id, :project_id => @project.id) if role.allowed_to?(:is_manager)
 | |
|                 # ProjectInfo.create(:name => "test", :user_id => 123)
 | |
|               end
 | |
|               ## end
 | |
|             end
 | |
|           else
 | |
|             members << Member.new(:role_ids => params[:membership][:role_ids], :user_id => params[:membership][:user_id])
 | |
|             user_grades << UserGrade.new(:user_id => params[:membership][:user_id], :project_id => @project.id)
 | |
|             ## added by nie
 | |
|             if (params[:membership][:role_ids])
 | |
|               role = Role.find(params[:membership][:role_ids][0])
 | |
|               project_info << ProjectInfo.new(:project_id => @project.id, :user_id => params[:membership][:user_id]) if role.allowed_to?(:is_manager)
 | |
|             end
 | |
|             ## end
 | |
|           end
 | |
|           @project.members << members
 | |
|           # added by nie
 | |
|           @project.project_infos << project_info
 | |
|           @project.user_grades << user_grades unless user_grades.first.user_id.nil?
 | |
|           # end
 | |
|         end
 | |
|         if members.present? && members.all? { |m| m.valid? }
 | |
|           members.each do |member|
 | |
|             AppliedProject.deleteappiled(member.user_id, @project.id)
 | |
|           end
 | |
|         end
 | |
|         if params[:flag]
 | |
|           unless members.present? && members.all? {|m| m.valid? }
 | |
|             flash[:error] = members.empty? ? l(:label_user_role_null) :members.collect {|m| m.errors.full_messages}.flatten.uniq.join(', ')
 | |
|           else
 | |
|             flash[:notice] = l(:label_invite_success)
 | |
|           end
 | |
|           respond_to do |format|
 | |
|             format.html { redirect_to invite_members_project_url(@project) }
 | |
|           end
 | |
|         else
 | |
|           unless members.present? && members.all? {|m| m.valid? }
 | |
|             @project_error_message = members.empty? ? l(:label_user_role_null) :members.collect {|m| m.errors.full_messages}.flatten.uniq.join(', ')
 | |
|           else
 | |
|             @succes_message = "添加成功"
 | |
|           end
 | |
|           respond_to do |format|
 | |
|             format.html { redirect_to_settings_in_projects }
 | |
|             format.js
 | |
|             format.api {
 | |
|               @member = members.first
 | |
|               if @member.valid?
 | |
|                 render :action => 'show', :status => :created, :location => membership_url(@member)
 | |
|               else
 | |
|                 render_validation_errors(@member)
 | |
|               end
 | |
|             }
 | |
|           end
 | |
|         end
 | |
|       elsif @course
 | |
|         course_info = []
 | |
|         if params[:membership]
 | |
|           @create_member_error_messages = "角色不能留空" unless params[:membership][:role_ids]
 | |
|           @create_member_error_messages = "用户不能留空" unless params[:membership][:user_ids]
 | |
| 
 | |
|           if params[:membership][:user_ids]
 | |
|             attrs = params[:membership].dup
 | |
|             user_ids = attrs.delete(:user_ids)
 | |
|             user_ids.each do |user_id|
 | |
|               member =  Member.new(:role_ids => params[:membership][:role_ids], :user_id => user_id)
 | |
|               role = Role.find_by_id(params[:membership][:role_ids])
 | |
|               # 这里的判断只能通过角色名,可以弄成常量
 | |
|               if role && (role.name == "学生" || role.name == "Student")
 | |
|                 StudentsForCourse.create(:student_id => user_id, :course_id =>@course.id)
 | |
|               end
 | |
|               members << member
 | |
|               #user_grades << UserGrade.new(:user_id => user_id, :course_id => @course.id)
 | |
|               if (params[:membership][:role_ids])
 | |
|                 role = Role.find(params[:membership][:role_ids][0])
 | |
|                 course_info << CourseInfo.new(:user_id => user_id, :course_id => @course.id)  if role.allowed_to?(:is_manager)
 | |
|               end
 | |
|             end
 | |
|           else
 | |
|             members << Member.new(:role_ids => params[:membership][:role_ids], :user_id => params[:membership][:user_id])
 | |
|             if (params[:membership][:role_ids])
 | |
|               role = Role.find(params[:membership][:role_ids][0])
 | |
|               course_info << CourseInfo.new(:course_id => @course.id, :user_id => params[:membership][:user_id]) if role.allowed_to?(:is_manager)
 | |
|             end
 | |
|           end
 | |
|           @course.members << members
 | |
|           @course.course_infos << course_info
 | |
| 
 | |
|           @roles = Role.givable.all[3..5]
 | |
|           members = @course.member_principals.includes(:roles, :principal).all.sort
 | |
|         else
 | |
|           @create_member_error_messages = l(:label_user_role_null)
 | |
|         end
 | |
|         respond_to do |format|
 | |
|           format.html { redirect_to_settings_in_courses }
 | |
|           format.js { @members = members; @applied_members = applied_members; }
 | |
|           format.api {
 | |
|             @member = members.first
 | |
|             if @member.valid?
 | |
|               render :action => 'show', :status => :created, :location => membership_url(@member)
 | |
|             else
 | |
|               render_validation_errors(@member)
 | |
|             end
 | |
|           }
 | |
|         end
 | |
|       end     # end of  if @project
 | |
| 
 | |
|     end  # end of params[:refusal_button]
 | |
| 
 | |
| 
 | |
| 
 | |
|   end
 | |
| 
 | |
|   def update
 | |
|     #modify by nwb
 | |
|     #增加对课程成员修改的支持
 | |
|     if @project
 | |
|       if params[:membership]
 | |
|         @member.role_ids = params[:membership][:role_ids]
 | |
| 
 | |
|         #added by nie
 | |
|         if (params[:membership][:role_ids])
 | |
|           role = Role.find(params[:membership][:role_ids][0])
 | |
|           if role.allowed_to?(:is_manager)
 | |
|             @projectInfo = ProjectInfo.new(:user_id => @member.user_id, :project_id => @project.id)
 | |
|             @projectInfo.save
 | |
|           else
 | |
|             user_admin = ProjectInfo.where("user_id = ? and project_id = ?", @member.user_id, @project.id)
 | |
|             if user_admin.size > 0
 | |
|               user_admin.each do |user|
 | |
|                 user.destroy
 | |
|               end
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
| 
 | |
|       saved = @member.save
 | |
|       respond_to do |format|
 | |
|         format.html { redirect_to_settings_in_projects }
 | |
|         format.js
 | |
|         format.api {
 | |
|           if saved
 | |
|             render_api_ok
 | |
|           else
 | |
|             render_validation_errors(@member)
 | |
|           end
 | |
|         }
 | |
|       end
 | |
|     elsif @course
 | |
|       if params[:membership]
 | |
|         @member.role_ids = params[:membership][:role_ids]
 | |
| 
 | |
|         if (params[:membership][:role_ids])
 | |
|           role = Role.find(params[:membership][:role_ids][0])
 | |
|           # 这里的判断只能通过角色名,可以弄成常量
 | |
|           if role.name == "学生"  || role.name == "Student"
 | |
|             StudentsForCourse.create(:student_id => @member.user_id, :course_id =>@course.id)
 | |
|           else
 | |
|             joined = StudentsForCourse.where('student_id = ? and course_id = ?', @member.user_id,@course.id)
 | |
|             joined.each do |join|
 | |
|               join.delete
 | |
|             end
 | |
|             @member.course_group_id = 0
 | |
|           end
 | |
|           if role.allowed_to?(:is_manager)
 | |
|             @courseInfo = CourseInfos.new(:user_id => @member.user_id, :course_id => @course.id)
 | |
|             @courseInfo.save
 | |
|           else
 | |
|             user_admin = CourseInfos.where("user_id = ? and course_id = ?", @member.user_id, @course.id)
 | |
|             if user_admin.size > 0
 | |
|               user_admin.each do |user|
 | |
|                 user.destroy
 | |
|               end
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|         @roles = Role.givable.all[3..5]
 | |
|         @members = @course.member_principals.includes(:roles, :principal).all.sort
 | |
|         @member = @course.members.new
 | |
|       end
 | |
| 
 | |
|       saved = @member.save
 | |
|       respond_to do |format|
 | |
|         format.html { redirect_to_settings_in_courses }
 | |
|         format.js
 | |
|         format.api {
 | |
|           if saved
 | |
|             render_api_ok
 | |
|           else
 | |
|             render_validation_errors(@member)
 | |
|           end
 | |
|         }
 | |
|       end
 | |
|     end
 | |
| 
 | |
|   end
 | |
| 
 | |
|   def destroy
 | |
|     #modify by nwb
 | |
|     #课程成员删除修改
 | |
|     if @project
 | |
|       if request.delete? && @member.deletable?
 | |
|         @member.destroy
 | |
|         # end
 | |
|         user_admin = ProjectInfo.where("user_id = ? and project_id = ?", @member.user_id, @project.id)
 | |
|         if user_admin.size > 0
 | |
|           user_admin.each do |user|
 | |
|             user.destroy
 | |
|           end
 | |
|         end
 | |
|         user_grade = UserGrade.where("user_id = ? and project_id = ?", @member.user_id, @project.id)
 | |
|         if user_grade.size > 0
 | |
|           user_grade.each do |grade|
 | |
|             grade.destroy
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|       respond_to do |format|
 | |
|         format.html { redirect_to_settings_in_projects }
 | |
|         format.js
 | |
|         format.api {
 | |
|           if @member.destroyed?
 | |
|             render_api_ok
 | |
|           else
 | |
|             head :unprocessable_entity
 | |
|           end
 | |
|         }
 | |
|       end
 | |
|     elsif @course
 | |
|       if request.delete? && @member.deletable?
 | |
|         @member.destroy
 | |
|         user_admin = CourseInfos.where("user_id = ? and course_id = ?", @member.user_id, @course.id)
 | |
|         if user_admin.size > 0
 | |
|           user_admin.each do |user|
 | |
|             user.destroy
 | |
|           end
 | |
|         end
 | |
|         joined = StudentsForCourse.where('student_id = ? and course_id = ?', @member.user_id,@course.id)
 | |
|         joined.each do |join|
 | |
|           join.delete
 | |
|         end
 | |
|         @roles = Role.givable.all[3..5]
 | |
|         @members = @course.member_principals.includes(:roles, :principal).all.sort
 | |
|       end
 | |
|       respond_to do |format|
 | |
|         format.html { redirect_to_settings_in_courses }
 | |
|         format.js
 | |
|         format.api {
 | |
|           if @member.destroyed?
 | |
|             render_api_ok
 | |
|           else
 | |
|             head :unprocessable_entity
 | |
|           end
 | |
|         }
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def autocomplete
 | |
|     @flag = params[:flag] || false
 | |
|     respond_to do |format|
 | |
|       format.js
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def redirect_to_settings_in_projects
 | |
|     redirect_to settings_project_url(@project, :tab => 'members')
 | |
|   end
 | |
| 
 | |
|   def redirect_to_settings_in_courses
 | |
|     redirect_to settings_course_url(@course, :tab => 'members')
 | |
|   end
 | |
| end
 |