class CoursesController < ApplicationController
include MessagesHelper
include ExportHelper
# model validation error
rescue_from ActiveRecord :: RecordInvalid do | ex |
render_error ( ex . record . errors . full_messages . join ( ',' ) )
end
# form validation error
rescue_from ActiveModel :: ValidationError do | ex |
render_error ( ex . model . errors . full_messages . join ( ',' ) )
end
before_action :require_login , except : [ :index , :show , :students , :teachers , :board_list , :mine , :all_course_groups ,
:left_banner , :top_banner , :informs , :online_learning , :course_groups ]
before_action :check_account , only : [ :new , :create , :apply_to_join_course , :join_excellent_course ]
before_action :check_auth , except : [ :index , :show , :students , :teachers , :board_list , :mine , :all_course_groups ,
:left_banner , :top_banner , :apply_to_join_course , :exit_course , :course_groups ]
before_action :set_course , only : [ :show , :update , :destroy , :settings , :set_invite_code_halt ,
:set_public_or_private , :search_teacher_candidate , :teachers , :apply_teachers ,
:top_banner , :left_banner , :add_teacher_popup , :add_teacher , :inform_up , :inform_down ,
:graduation_group_list , :create_graduation_group , :join_graduation_group ,
:course_group_list , :set_course_group , :change_course_admin , :change_course_teacher ,
:delete_course_teacher , :teacher_application_review , :students , :all_course_groups ,
:transfer_to_course_group , :delete_from_course , :search_users , :add_students_by_search ,
:base_info , :get_historical_courses , :create_group_by_importing_file ,
:attahcment_category_list , :export_member_scores_excel , :duplicate_course ,
:switch_to_teacher , :switch_to_assistant , :switch_to_student , :exit_course ,
:informs , :update_informs , :online_learning , :update_task_position , :tasks_list ,
:join_excellent_course , :export_couser_info , :export_member_act_score , :new_informs ,
:delete_informs , :change_member_role , :course_groups , :join_course_group , :statistics ,
:work_score , :act_score , :calculate_all_shixun_scores ]
before_action :user_course_identity , except : [ :join_excellent_course , :index , :create , :new , :apply_to_join_course ,
:search_course_list , :get_historical_course_students , :mine , :search_slim , :board_list ]
before_action :teacher_allowed , only : [ :update , :destroy , :settings , :search_teacher_candidate ,
:transfer_to_course_group , :delete_from_course , :export_member_scores_excel ,
:search_users , :add_students_by_search , :get_historical_courses , :add_teacher_popup ,
:add_teacher , :export_couser_info , :export_member_act_score ,
:update_informs , :new_informs , :delete_informs , :switch_to_student ]
before_action :admin_allowed , only : [ :set_invite_code_halt , :set_public_or_private , :change_course_admin ,
:set_course_group , :create_group_by_importing_file ,
:update_task_position , :tasks_list ]
before_action :teacher_or_admin_allowed , only : [ :graduation_group_list , :create_graduation_group , :join_graduation_group ,
:change_course_teacher , :course_group_list , :change_member_role , :inform_up , :inform_down ,
:teacher_application_review , :apply_teachers , :delete_course_teacher ]
before_action :validate_course_name , only : [ :create , :update ]
before_action :find_board , only : :board_list
before_action :validate_page_size , only : :mine
before_action :course_tasks , only : [ :tasks_list , :update_task_position ]
before_action :validate_inform_params , only : [ :update_informs , :new_informs ]
before_action :course_member_allowed , only : [ :statistics , :work_score , :act_score , :calculate_all_shixun_scores ]
if RUBY_PLATFORM =~ / linux /
require 'simple_xlsx_reader'
require 'roo-xls'
end
# GET /courses
# GET /courses.json
def index
@user = current_user
# 根据分类查询课堂(全部,我的,最新,最热)
@order = params [ :order ] . present? ? params [ :order ] : " all "
@courses = current_laboratory . all_courses . not_deleted
if @order == " visits "
order_str = " courses.id = 1309 DESC, courses.visits DESC "
@courses = @courses . where ( is_hidden : 0 )
else
order_str = " courses.id = 1309 DESC, courses.homepage_show DESC, courses.created_at desc "
@courses = @courses . where ( is_hidden : 0 , is_end : 0 )
end
# 金课未开课的不显示在首页
@courses = @courses . where ( " start_date is null or start_date <= ' #{ Date . today } ' " )
# 根据搜索关键字进一步筛选
if params [ :search ] . present?
# REDO:Extension
#user_ids = User.includes(user_extension: :school).where("schools.name like ?", "%#{params[:search]}%").pluck(:id)
#course_ids = CourseMember.includes(:user, :course).where("course_members.course_id in (?) and course_members.role in (1,2,3)
# and CONCAT(users.lastname, users.firstname) like ?", @courses.map(&:id), "%#{params[:search]}%")
# .pluck(:course_id)
#@courses = @courses.where("name like ?", "%#{params[:search]}%").or(@courses.where(tea_id: user_ids)).or(@courses.where(id: course_ids))
# 6:21 daiao
sql = %Q{
( course_members . role in ( 1 , 2 , 3 ) and CONCAT ( users . lastname , users . firstname ) like :keyword ) or courses . name like :keyword
or schools . name like :keyword
}
@courses = @courses . joins ( :school , course_members : :user )
. where ( " #{ sql } " , keyword : " % #{ params [ :search ] } % " ) . distinct
end
@courses_count = @courses . count ( " courses.id " )
@courses = @courses . order ( order_str )
# 分页
page = params [ :page ] || 1
limit = params [ :limit ] || 16
@courses = @courses . page ( page ) . per ( limit )
@courses = @courses . preload ( :school , :none_hidden_course_modules , teacher : :user_extension )
end
def visits_plus_one
new_visits = @course . visits + 1
@course . update_visits ( new_visits )
normal_status ( " 成功 " )
end
# GET /courses/1
# GET /courses/1.json
def show
# render :json => {first_category_url: module_url(course.course_modules.where.not(module_type: "activity").where(hidden: 0).first, course)}
end
# GET /courses/new
def new
@course = Course . new
unless params [ :subject_id ] . blank?
subject = Subject . find_by ( id : params [ :subject_id ] , excellent : 1 )
render :json = > { status : 0 , course_name : " #{ subject & . name } 第 #{ subject & . courses & . count . to_i + 1 } 期 " }
else
normal_status ( " 成功 " )
end
end
# Get /courses/:id/settings
# Edit Page
def settings
@course_modules = @course . course_modules . where . not ( module_type : 'activity' )
end
# POST /courses
# POST /courses.json
def create
begin
ActiveRecord :: Base . transaction do
@course = Course . new ( name : params [ :name ] , class_period : params [ :class_period ] , credit : params [ :credit ] ,
end_date : params [ :end_date ] , is_public : params [ :is_public ] , school_id : @school . id ,
authentication : params [ :authentication ] , professional_certification : params [ :professional_certification ] )
@course . tea_id = current_user . id
if params [ :subject_id ] . blank?
@course_list_name = params [ :course_list_name ] . strip
@course_list = CourseList . find_by ( name : @course_list_name )
if @course_list
@course . course_list_id = @course_list . id
else
new_course_list = CourseList . create! ( name : @course_list_name , user_id : current_user . id , is_admin : 0 )
@course . course_list_id = new_course_list . id
end
else
subject = Subject . find_by! ( id : params [ :subject_id ] )
@course . start_date = params [ :start_date ]
@course . subject_id = subject . id
@course . excellent = true
course_list = CourseList . find_by ( name : subject . name ) || CourseList . create! ( name : subject . name , user_id : current_user . id , is_admin : 0 )
@course . course_list_id = course_list . id
end
@course . is_end = @course . end_date . present? && @course . end_date < Date . today
if @course . save!
@course . generate_invite_code
CourseInfo . create! ( user_id : current_user . id , course_id : @course . id )
CourseMember . create! ( course_id : @course . id , user_id : current_user . id , role : 1 )
# 将实践课程的教学团队成员以教师身份加入课堂
if @course . subject
@course . subject . subject_members . where . not ( user_id : current_user . id ) . each do | s_member |
CourseMember . create! ( course_id : @course . id , user_id : s_member . user_id , role : 2 )
end
Inform . create ( container : @course , description : @subject . learning_notes , name : " 学习须知 " )
@course . create_stages @course . subject
end
course_module_types = params [ :course_module_types ]
@course . create_course_modules ( course_module_types )
end
end
CreateSubjectCourseStudentJob . perform_later ( @course . id ) if @course . subject && @course . subject . subject_appointments . count > 0
rescue = > e
uid_logger_error ( e . message )
tip_exception ( e . message )
raise ActiveRecord :: Rollback
end
end
# PATCH/PUT /courses/1
# PATCH/PUT /courses/1.json
def update
ActiveRecord :: Base . transaction do
begin
extra_params = Hash . new
extra_params [ :school_id ] = @school . id
if @course . is_end && ( course_params [ :end_date ] . blank? || course_params [ :end_date ] . to_date > = Date . today )
extra_params [ :is_end ] = 0
elsif ! @course . is_end && ! course_params [ :end_date ] . blank? && course_params [ :end_date ] . to_date < Date . today
extra_params [ :is_end ] = 1
end
extra_params [ :authentication ] = params [ :authentication ]
extra_params [ :professional_certification ] = params [ :professional_certification ]
if @course . subject
@course . start_date = params [ :start_date ]
else
extra_params [ :is_public ] = params [ :is_public ] . present? ? params [ :is_public ] : 0
@course_list_name = params [ :course_list_name ] . strip
@course_list = CourseList . find_by ( name : @course_list_name )
if @course_list
extra_params [ :course_list_id ] = @course_list . id
else
new_course_list = CourseList . create ( name : @course_list_name , user_id : current_user . id , is_admin : 0 )
extra_params [ :course_list_id ] = new_course_list . id
end
end
@course . update_attributes! ( course_params . merge ( extra_params ) )
@course . update_course_modules ( params [ :course_module_types ] )
Rails . logger . info ( " # # # # # # # # # # # # # # # course_update_end " )
normal_status ( 0 , " 成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 课堂更新失败,原因: #{ e . message } " )
raise ActiveRecord :: Rollback
end
end
end
def statistics
max_exp = User . where ( id : @course . students . pluck ( :user_id ) ) . pluck ( :experience ) . max
limit = params [ :limit ] || 5
@top_scores = course_statistics ( @course , max_exp , limit )
end
def work_score
sort = params [ :sort ] || " desc "
group_ids = params [ :group_ids ] . is_a? ( Array ) ? params [ :group_ids ] : params [ :group_ids ] . split ( " , " ) if params [ :group_ids ]
@course_members = course_work_scores @course , sort , group_ids
if @user_course_identity == Course :: STUDENT
user_ids = @course_members . map ( & :user_id )
@rank = user_ids . index ( current_user . id ) . to_i + 1
@course_members = @course_members . select { | member | member . user_id == current_user . id }
else
@all_count = @course_members . size
@course_members = paginate @course_members
end
end
def act_score
group_ids = params [ :group_ids ] . is_a? ( Array ) ? params [ :group_ids ] : params [ :group_ids ] . split ( " , " ) if params [ :group_ids ]
all_members = course_act_scores @course , group_ids
@course_members = all_members [ 0 .. 9 ]
# if @user_course_identity == Course::STUDENT
# user_ids = all_members.map(&:user_id)
# rank = user_ids.index(current_user.id).to_i + 1
# if rank > 10
# current_member = all_members.select{|member| member.user_id == current_user.id}.first
# @course_members << current_member if current_member.present?
# end
# end
end
def join_excellent_course
tip_exception ( " 您已是课堂成员 " ) if current_user . member_of_course? ( @course )
tip_exception ( " 请通过邀请码加入课堂 " ) unless @course . excellent
tip_exception ( " 该课堂已结束 " ) if @course . is_end
begin
new_student = CourseMember . new ( user_id : current_user . id , course_id : @course . id , role : 4 )
new_student . save!
CourseAddStudentCreateWorksJob . perform_later ( @course . id , [ current_user . id ] )
StudentJoinCourseNotifyJob . perform_later ( current_user . id , @course . id )
normal_status ( 0 , " 加入成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( e . message )
end
end
def informs
@informs = @course . informs . order ( " position desc " )
end
def inform_up
inform = @course . informs . find_by ( id : params [ :inform_id ] )
next_inform = inform . next_inform
ActiveRecord :: Base . transaction do
if next_inform . blank?
render_error ( '已经到达最顶部' )
else
inform . update_attribute ( :position , ( inform . position + 1 ) )
next_inform . update_attribute ( :position , inform . position - 1 )
render_ok
end
end
end
def inform_down
inform = @course . informs . find_by ( id : params [ :inform_id ] )
last_inform = inform . last_inform
ActiveRecord :: Base . transaction do
if last_inform . blank?
render_error ( '已经到达最底部' )
else
inform . update_attribute ( :position , ( inform . position - 1 ) )
last_inform . update_attribute ( :position , inform . position + 1 )
render_ok
end
end
end
def new_informs
inform = Inform . new ( container : @course )
inform . name = params [ :name ]
inform . description = params [ :description ]
inform . position = @course . informs . maximum ( :position ) . to_i + 1
inform . save!
normal_status ( " 创建成功 " )
end
def update_informs
inform = @course . informs . find_by ( id : params [ :inform_id ] )
inform . update_attributes! ( name : params [ :name ] , description : params [ :description ] )
normal_status ( " 更新成功 " )
end
def delete_informs
inform = @course . informs . find_by ( id : params [ :inform_id ] )
@course . informs . where ( " position > ? " , inform . position ) . update_all ( " position = position - 1 " )
inform . destroy!
normal_status ( " 删除成功 " )
end
def online_learning
@subject = @course . subject
@stages = @course . course_stages . includes ( :shixuns )
@user = current_user
@myshixuns = @user . myshixuns . where ( shixun_id : @course . course_stage_shixuns . pluck ( :shixun_id ) )
@start_learning = @user_course_identity == Course :: STUDENT && @myshixuns . present?
end
def search_course_list
search = params [ :search ] ? " % #{ params [ :search ] . strip } % " : " %% "
@course_lists = CourseList . where ( " name like ? " , " #{ search } " )
@search_count = @course_lists . size
end
# 邀请码停用/启用
def set_invite_code_halt
begin
@course . update_attribute ( 'invite_code_halt' , @course . invite_code_halt == 0 ? 1 : 0 )
normal_status ( 0 , " 成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 停用/启用课堂失败 " )
end
end
# 设置课堂私有/公有
def set_public_or_private
begin
@course . update_attribute ( 'is_public' , @course . is_public == 1 ? 0 : 1 )
normal_status ( 0 , " 成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 设置课堂公有/私有失败 " )
end
end
# DELETE /courses/1
# DELETE /courses/1.json
def destroy
if @course . is_delete == 0
@course . delete!
Tiding . create! ( user_id : current_user . id , trigger_user_id : current_user . id , container_id : @course . id ,
container_type : 'DeleteCourse' , tiding_type : 'System' , belong_container : @course , extra : @course . name )
normal_status ( 0 , " 成功 " )
else
normal_status ( - 1 , " 课堂已删除,无需重复操作 " )
end
end
# 课堂的基本信息
def base_info
end
# --- 教师列表相关API --- START
# 教师列表以及教师搜索
def teachers
@search_str = params [ :search ] . present? ? params [ :search ] . strip : " "
if @course . try ( :id ) != 1309 || current_user . admin? || current_user . try ( :id ) == 15582
@teacher_list = @course . course_members . joins ( :user ) . where ( " course_members.role in (1, 2, 3)
and LOWER ( concat ( users . lastname , users . firstname ) ) LIKE ?" , " % #{ @search_str } % " )
else
@teacher_list = @course . course_members . joins ( :user ) . where ( " (course_members.role in (1, 3) or (course_members.user_id = #{ current_user . id }
and course_members . role = 2 ) ) and LOWER ( concat ( users . lastname , users . firstname ) )
LIKE ?" , " % #{ @search_str } % " )
end
@teacher_list_size = @teacher_list . size
@has_graduation_design = @course . course_modules . graduation_module_not_hidden . any?
sort = params [ :sort ] || " asc "
@order = params [ :order ] ? params [ :order ] . to_i : 1
if @order . present?
case @order
when 1
@teacher_list = @teacher_list . order ( " role #{ sort } " )
when 2
@teacher_list = @teacher_list . includes ( :user ) . order ( " CONVERT(CONCAT(users.lastname, users.firstname) USING gbk) COLLATE gbk_chinese_ci #{ sort } " )
when 3
@teacher_list = @teacher_list . includes ( :course , :graduation_group ) . order ( " graduation_groups.name #{ sort } " )
else
@teacher_list = @teacher_list . order ( " role #{ sort } " )
end
else
@teacher_list = @teacher_list . order ( " role #{ sort } " )
end
@is_admin = @user_course_identity < Course :: PROFESSOR
@applications_size = CourseMessage . unhandled_join_course_requests_by_course ( @course ) . size
page = params [ :page ] || 1
limit = params [ :limit ] || 20
@teacher_list = @teacher_list . page ( page ) . per ( limit )
@teacher_list = @teacher_list . preload ( :graduation_group , :user , :teacher_course_groups )
end
def apply_teachers
search_str = params [ :search ] . present? ? params [ :search ] . strip : " "
@applications = CourseMessage . unhandled_join_course_requests_by_course ( @course ) .
joins ( " join users on course_messages.course_message_id=users.id " ) .
where ( " LOWER(concat(users.lastname, users.firstname)) LIKE ? " , " % #{ search_str } % " )
if @course . try ( :id ) != 1309 || current_user . admin? || current_user . try ( :id ) == 15582
teacher_list = @course . course_members . where ( " course_members.role in (1, 2, 3) " )
else
teacher_list = @course . course_members . where ( " (course_members.role in (1, 3) or (course_members.user_id = #{ current_user . id }
and course_members . role = 2 ) ) " )
end
@teacher_list_size = teacher_list . size
@applications_size = CourseMessage . unhandled_join_course_requests_by_course ( @course ) . size
@is_admin = @user_course_identity < Course :: PROFESSOR
end
# 打开添加教师或助教弹窗时访问的接口(需要返回该课堂所有答辩组和所有)
def add_teacher_popup
@graduation_groups = @course . graduation_groups
@course_groups = @course . course_groups
@school_name = School . find ( current_user . school_id ) . try ( :name )
end
# 添加教师或助教弹窗中的搜索接口
def search_teacher_candidate
name = params [ :name ]
school_name = params [ :school_name ]
# user_ids_of_course_members = @course.course_members.where(role: [1,2,3]).pluck(:user_id)
# @users = User.where.not(id: user_ids_of_course_members)
@users = User . where ( status : User :: STATUS_ACTIVE )
@users = @users . where ( laboratory_id : current_laboratory . id ) unless current_laboratory . main_site?
@users = @users . where ( " concat(users.lastname, users.firstname) like '% #{ name } %' " ) if name . present?
# REDO:Extension
@users = @users . joins ( user_extension : :school ) . where ( " schools.name like '% #{ school_name } %' " ) if school_name . present?
@users_size = @users . size
page = params [ :page ] || 1
limit = params [ :limit ] || 10
@users = @users . page ( page ) . per ( limit )
end
# 添加教师或者助教
def add_teacher
ActiveRecord :: Base . transaction do
begin
@user_list = params [ :user_list ] . present? ? params [ :user_list ] : [ ]
return tip_exception ( " 请先选择成员 " ) if @user_list . blank?
@graduation_group_id = params [ :graduation_group_id ] . present? ? GraduationGroup . find ( params [ :graduation_group_id ] ) . id : 0
@course_group_id = params [ :course_group_id ] . present? ? CourseGroup . find ( params [ :course_group_id ] ) . id : 0
role = params [ :role ] . to_i
teacher_ids = [ ]
@user_list . each do | user |
active_student_exist = CourseMember . where ( user_id : user [ :user_id ] , role : 4 , course_id : @course . id , is_active : 1 ) . any?
is_active = active_student_exist ? 0 : 1
user_id = User . find ( user [ :user_id ] ) . id
existing_teacher = CourseMember . find_by ( course_id : @course . id , user_id : user_id , role : % i [ CREATOR PROFESSOR ASSISTANT_PROFESSOR ] )
if existing_teacher . blank?
teacher_ids << user_id
member = CourseMember . create ( course_id : @course . id , graduation_group_id : @graduation_group_id , user_id : user_id , role : role , is_active : is_active )
member . teacher_course_groups << TeacherCourseGroup . new ( course_group_id : @course_group_id , user_id : user_id , course_id : @course . id ) if @course_group_id != 0
end
end
TeacherInviteJoinCourseNotifyJob . perform_later ( current_user . id , @course . id , role , teacher_ids ) if teacher_ids . present?
normal_status ( 0 , " 添加成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( - 1 , " 添加失败 " )
raise ActiveRecord :: Rollback
end
end
end
# 获取当前课堂的所有答辩组
def graduation_group_list
@graduation_group_list = @course . graduation_groups
end
# 给当前课堂增加答辩组
def create_graduation_group
begin
if params [ :name ] . present?
identical_exist = GraduationGroup . where ( course_id : @course . id , name : params [ :name ] ) . any?
if identical_exist
normal_status ( - 1 , " 已存在同名答辩组 " )
else
GraduationGroup . create ( course_id : @course . id , user_id : current_user . id , name : params [ :name ] )
normal_status ( 0 , " 成功 " )
end
else
tip_exception ( - 1 , " 答辩组名称不能为空 " )
end
rescue = > e
uid_logger_error ( e . message )
tip_exception ( - 1 , " 添加失败 " )
raise ActiveRecord :: Rollback
end
end
# 将教师加入答辩组
def join_graduation_group
ActiveRecord :: Base . transaction do
begin
@course_member_list = params [ :course_member_list ] . present? ? params [ :course_member_list ] : [ ]
graduation_group_id = GraduationGroup . find ( params [ :graduation_group_id ] . to_i ) . id
@course_member_list . each do | course_member |
course_member = CourseMember . find ( course_member [ :course_member_id ] . to_i )
course_member . update_attributes ( graduation_group_id : graduation_group_id )
end
normal_status ( 0 , " 成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( - 1 , " 加入失败 " )
raise ActiveRecord :: Rollback
end
end
end
# 获取当前课堂的所有分班, 以及当前教师是否对分班具有管理权限的状态
def course_group_list
course_member_id = params [ :course_member_id ]
user_id = params [ :user_id ]
@existed_course_group_ids = TeacherCourseGroup . where ( course_id : @course . id , course_member_id : course_member_id , user_id : user_id )
. pluck ( :course_group_id )
@all_course_groups = CourseGroup . where ( course_id : @course . id )
end
# 设置教师的管理权限(即设置该教师所能管理的分班)
def set_course_group
ActiveRecord :: Base . transaction do
begin
course_group_ids = params [ :course_group_ids ]
user_id = User . find ( params [ :user_id ] . to_i ) . id
course_member_id = CourseMember . find ( params [ :course_member_id ] ) . id
teacher_course_groups = TeacherCourseGroup . where ( course_id : @course . id , user_id : user_id , course_member_id : course_member_id )
teacher_course_groups . destroy_all
course_group_ids . each do | course_group_id |
course_group_id = CourseGroup . where ( id : course_group_id . to_i , course_id : @course . id ) . first . id
TeacherCourseGroup . create ( course_id : @course . id , user_id : user_id , course_member_id : course_member_id , course_group_id : course_group_id )
end
normal_status ( 0 , " 成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 分配管理权限失败 " )
raise ActiveRecord :: Rollback
end
end
end
# 变更管理员
def change_course_admin
ActiveRecord :: Base . transaction do
begin
new_admin_user = User . find ( params [ :user_id ] . to_i )
new_admin = CourseMember . find_by! ( id : params [ :course_member_id ] . to_i , course_id : @course . id , user_id : new_admin_user . id )
current_admin = CourseMember . find_by! ( course_id : @course . id , role : 1 )
new_admin . CREATOR!
current_admin . PROFESSOR!
@course . update_attributes! ( tea_id : new_admin_user . id )
normal_status ( 0 , " 变更管理员成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 变更管理员失败 " )
raise ActiveRecord :: Rollback
end
end
end
# 修改角色
def change_member_role
tip_exception ( " 请至少选择一个角色 " ) if params [ :roles ] . blank?
tip_exception ( " 不能具有老师、助教两种角色 " ) if params [ :roles ] . include? ( " PROFESSOR " ) && params [ :roles ] . include? ( " ASSISTANT_PROFESSOR " )
tip_exception ( " 管理员不能切换为助教或老师 " ) if params [ :user_id ] . to_i == @course . tea_id &&
( params [ :roles ] . include? ( " PROFESSOR " ) || params [ :roles ] . include? ( " ASSISTANT_PROFESSOR " ) )
course_members = @course . course_members . where ( user_id : params [ :user_id ] )
tip_exception ( " 非课堂成员不能修改角色 " ) if course_members . blank?
ActiveRecord :: Base . transaction do
# 第一次修改为教师或助教身份时直接创建数据
if params [ :roles ] . include? ( " CREATOR " )
teacher_member = course_members . where ( role : % i [ CREATOR ] ) . take
elsif ( params [ :roles ] . include? ( " PROFESSOR " ) || params [ :roles ] . include? ( " ASSISTANT_PROFESSOR " ) ) && ! course_members . exists? ( role : % i [ PROFESSOR ASSISTANT_PROFESSOR ] )
teacher_member = CourseMember . create! ( course_id : @course . id , user_id : params [ :user_id ] , role : params [ :roles ] . include? ( " PROFESSOR " ) ? 2 : 3 )
# 如果有未审批的申请教师/助教的记录,则修改状态为已审批
apply_teacher = CourseMessage . where ( course_id : @course . id , course_message_id : params [ :user_id ] , status : 0 ) . last
apply_teacher . update! ( status : 1 , apply_user_id : current_user . id ) if apply_teacher . present?
elsif course_members . exists? ( role : % i [ PROFESSOR ASSISTANT_PROFESSOR ] )
teacher_member = course_members . where ( role : % i [ PROFESSOR ASSISTANT_PROFESSOR ] ) . take
if params [ :roles ] . include? ( " PROFESSOR " ) || params [ :roles ] . include? ( " ASSISTANT_PROFESSOR " )
# 如果之前有老师身份且老师身份要调整时, 只需要修改role字段
if ! params [ :roles ] . include? ( teacher_member . role ) && params [ :roles ] . include? ( " PROFESSOR " )
teacher_member . PROFESSOR!
elsif ! params [ :roles ] . include? ( teacher_member . role ) && params [ :roles ] . include? ( " ASSISTANT_PROFESSOR " )
teacher_member . ASSISTANT_PROFESSOR!
end
teacher_member . save!
else
# 不含教师的参数时删除记录
teacher_member . destroy!
# CourseDeleteStudentNotifyJob.perform_later(@course.id, [teacher_member.user_id], current_user.id)
end
end
# 学生身份的处理
student_member = course_members . where ( role : % i [ STUDENT ] ) . take
# 不存在则创建学生身份
if params [ :roles ] . include? ( " STUDENT " ) && student_member . blank?
correspond_teacher_exist = CourseMember . exists? ( user_id : params [ :user_id ] , is_active : 1 , course_id : @course . id , role : % i [ CREATOR PROFESSOR ASSISTANT_PROFESSOR ] )
new_student = CourseMember . new ( user_id : params [ :user_id ] , course_id : @course . id , role : 4 )
new_student . is_active = 0 if correspond_teacher_exist
new_student . save!
CourseAddStudentCreateWorksJob . perform_later ( @course . id , [ params [ :user_id ] ] )
# StudentJoinCourseNotifyJob.perform_later(current_user.id, course.id)
elsif ! params [ :roles ] . include? ( " STUDENT " ) && student_member . present?
# 删除学生身份时激活老师身份
teacher_member . update_attributes! ( is_active : 1 ) if student_member . is_active && teacher_member . present?
student_member . destroy!
CourseDeleteStudentDeleteWorksJob . perform_later ( @course . id , [ params [ :user_id ] ] )
# CourseDeleteStudentNotifyJob.perform_later(@course.id, [params[:user_id]], current_user.id)
elsif params [ :roles ] . include? ( " STUDENT " ) && student_member . present? && ! params [ :roles ] . include? ( " PROFESSOR " ) && ! params [ :roles ] . include? ( " ASSISTANT_PROFESSOR " )
# 学生身份存在且学生没有教师身份时更新is_active
student_member . update_attributes! ( is_active : 1 )
end
normal_status ( 0 , " 修改成功 " )
end
end
# 教师和助教角色转换的接口
def change_course_teacher
begin
course_member = CourseMember . find_by! ( id : params [ :course_member_id ] . to_i , course_id : @course . id )
if course_member . PROFESSOR?
course_member . ASSISTANT_PROFESSOR!
elsif course_member . ASSISTANT_PROFESSOR?
course_member . PROFESSOR!
else
tip_exception ( " 变更教师/助教失败 " )
end
course_member . save!
normal_status ( 0 , " 变更教师/助教成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 变更教师/助教失败 " )
end
end
# 删除教师或助教
def delete_course_teacher
begin
course_member = CourseMember . find_by! ( id : params [ :course_member_id ] . to_i , course_id : @course . id )
tip_exception ( " 删除失败 " ) if course_member . CREATOR? or course_member . STUDENT?
course_student = CourseMember . find_by ( user_id : course_member . user_id , course_id : @course . id , role : % i [ STUDENT ] )
# Tiding.create!(user_id: course_member.user_id, trigger_user_id: current_user.id, container_id: @course.id,
# container_type: 'DeleteCourseMember', tiding_type: 'System', belong_container: @course, extra: @course.name)
CourseDeleteStudentNotifyJob . perform_later ( @course . id , [ course_member . user_id ] , current_user . id )
course_member . destroy!
course_student . update_attributes ( is_active : 1 ) if course_student . present? && ! course_student . is_active
normal_status ( 0 , " 删除成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 删除失败 " )
end
end
# 切换为教师
def switch_to_teacher
begin
course_member = @course . course_members . find_by! ( user_id : current_user . id , is_active : 1 )
tip_exception ( " 切换失败 " ) unless course_member . STUDENT?
course_teacher = CourseMember . find_by! ( user_id : current_user . id , role : % i [ CREATOR PROFESSOR ] , course_id : @course . id )
course_member . update_attributes ( is_active : 0 )
course_teacher . update_attributes ( is_active : 1 )
normal_status ( 0 , " 切换成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 切换失败 " )
end
end
# 切换为助教
def switch_to_assistant
begin
course_member = @course . course_members . find_by! ( user_id : current_user . id , is_active : 1 )
tip_exception ( " 切换失败 " ) unless course_member . STUDENT?
course_teacher = CourseMember . find_by! ( user_id : current_user . id , role : % i [ ASSISTANT_PROFESSOR ] , course_id : @course . id )
course_member . update_attributes ( is_active : 0 )
course_teacher . update_attributes ( is_active : 1 )
normal_status ( 0 , " 切换成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( " 切换失败 " )
end
end
# 切换为学生
def switch_to_student
ActiveRecord :: Base . transaction do
begin
course_member = @course . course_members . find_by! ( user_id : current_user . id , is_active : 1 )
tip_exception ( " 切换失败 " ) if course_member . STUDENT?
course_student = CourseMember . find_by ( user_id : current_user . id , role : % i [ STUDENT ] , course_id : @course . id )
course_member . update_attributes! ( is_active : 0 )
if course_student
course_student . update_attributes! ( is_active : 1 )
else
# 学生身份不存在则创建
CourseMember . create! ( user_id : current_user . id , role : 4 , course_id : @course . id )
CourseAddStudentCreateWorksJob . perform_later ( @course . id , [ current_user . id ] )
end
normal_status ( 0 , " 切换成功 " )
rescue = > e
uid_logger_error ( " switch_to_student error: #{ e . message } " )
tip_exception ( e . message )
raise ActiveRecord :: Rollback
end
end
end
def exit_course
course_student = CourseMember . find_by! ( user_id : current_user . id , role : % i [ STUDENT ] , course_id : @course . id )
tip_exception ( " 非课堂学生无法退出课堂 " ) unless course_student . STUDENT?
# 课堂如果还有其他身份的用户则更新is_active
course_teacher = CourseMember . find_by ( user_id : current_user . id , role : % i [ CREATOR PROFESSOR ASSISTANT_PROFESSOR ] , course_id : @course . id )
course_student . destroy!
course_teacher . update_attributes ( is_active : 1 ) if course_teacher . present? && ! course_teacher . is_active
CourseDeleteStudentDeleteWorksJob . perform_later ( @course . id , [ current_user . id ] )
normal_status ( 0 , " 退出成功 " )
end
# 教师申请加入课堂的审批
def teacher_application_review
ActiveRecord :: Base . transaction do
begin
course_message = CourseMessage . find_by! ( id : params [ :application_id ] . to_i , course_id : @course . id )
course_message . apply_user_id = current_user . id
applier_user = User . find_by! ( id : params [ :user_id ] . to_i )
approval = params [ :approval ] . to_i
if approval == 1
course_message . pass!
content = course_message . content . to_i
role = ( content == 3 || content == 7 ) ? 3 : ( ( content == 2 || content == 9 ) ? 2 : nil )
if role
tip_exception ( " 已存在教师/助教身份 " ) if CourseMember . where ( course_id : @course . id , user_id : applier_user . id , role : [ 1 , 2 , 3 ] ) . any?
else
tip_exception ( " 申请角色错误 " )
end
new_teacher = CourseMember . new ( course_id : @course . id , user_id : applier_user . id , role : role )
new_teacher . save!
# 课堂管理员才有分配权限, 且课堂分班数大于0
if @user_course_identity < Course :: PROFESSOR && @course . course_groups_count > 0 && params [ :group_id ] && params [ :group_id ] . size > 0
# 分班全选则是不限,不需要做处理
unless @course . course_groups . where ( id : params [ :group_id ] ) . size == @course . course_groups_count
@course . course_groups . where ( id : params [ :group_id ] ) . each do | group |
unless TeacherCourseGroup . where ( course_id : @course . id , user_id : applier_user . id , course_group_id : group . id , course_member_id : new_teacher . id ) . exists?
TeacherCourseGroup . create ( course_id : @course . id , user_id : applier_user . id , course_member_id : new_teacher . id , course_group_id : group . id )
end
end
end
end
elsif approval == 2
course_message . reject!
else
tip_exception ( " 参数错误 " )
end
course_message . save!
normal_status ( 0 , " 操作成功 " )
rescue = > e
uid_logger_error ( e . message )
tip_exception ( e . message )
raise ActiveRecord :: Rollback
end
end
end
# 已通过职业认证的教师复制课堂
def duplicate_course
return tip_exception ( " 没有复制权限 " ) unless current_user . admin? || current_user . is_teacher? || current_user . teacher_of_course? ( @course )
return tip_exception ( " 教师职业认证未通过 " ) unless current_user . pro_certification?
new_course = @course . self_duplicate
render json : { new_course_id : new_course . id }
end
# --- 教师列表相关API --- END
# --- 学生列表相关API --- START
# 学生列表(包括各个子分班的学生列表)及搜索
def students
search = params [ :search ] . present? ? params [ :search ] . strip : nil
order = params [ :order ] . present? ? params [ :order ] . to_i : 1
sort = params [ :sort ] . present? ? params [ :sort ] : " asc "
course_group_id = params [ :course_group_id ] . present? ? params [ :course_group_id ] . to_i : nil
@students = CourseMember . students ( @course )
if search . present?
# REDO:Extension
@students = @students . joins ( user : :user_extension ) . where ( " LOWER(CONCAT(users.lastname, users.firstname)) like ? or
user_extensions . student_id like ?" , " % #{ search } % " , " % #{ search } % " )
end
if order == 1
# REDO:Extension
@students = @students . includes ( user : :user_extension ) . order ( " user_extensions.student_id #{ sort } , users.login #{ sort } " )
elsif order == 2
@students = @students . includes ( :course_group ) . order ( " course_groups.position #{ sort } , users.login #{ sort } " )
else
# REDO:Extension
@students = @students . includes ( user : :user_extension ) . order ( " user_extensions.student_id #{ sort } , users.login #{ sort } " )
end
if course_group_id . present?
@students = @students . where ( course_group_id : course_group_id )
@course_group = CourseGroup . find ( course_group_id ) if course_group_id != 0
end
@students_count = @students . size
page = params [ :page ] || 1
limit = params [ :limit ] || 20
@students = @students . page ( page ) . per ( limit )
@students = @students . includes ( :course_group , user : :user_extension )
end
# 获取当前课程所有分班
def all_course_groups
if params [ :all ] # 返回所有分班
@course_groups_array = @course . course_groups . to_a
else # 返回权限下的分班
charge_group_ids = @course . charge_group_ids ( current_user )
@course_groups_array = @course . course_groups . where ( id : charge_group_ids ) . to_a
end
current_course_group_id = params [ :course_group_id ]
if current_course_group_id . present?
current_course_group = CourseGroup . find ( current_course_group_id )
@course_groups_array . delete ( current_course_group )
end
end
# 分班列表
def course_groups
@course_groups = @course . course_groups
@course_groups = @course_groups . where ( " name like ? " , " % #{ params [ :search ] } % " ) unless params [ :search ] . blank?
@all_group_count = @course_groups . size
@teachers = @course . teachers . includes ( :user , :teacher_course_groups ) if @user_course_identity < Course :: NORMAL
@current_group_id = @course . students . where ( user_id : current_user . id ) . take & . course_group_id if @user_course_identity == Course :: STUDENT
end
# 学生自动加入分班
def join_course_group
tip_exception ( " 学生才能加入分班 " ) if @user_course_identity != Course :: STUDENT
course_group = CourseGroup . find_by! ( id : params [ :course_group_id ] , course_id : @course . id )
member = CourseMember . find_by! ( user_id : current_user . id , course_id : @course . id , role : 4 )
if course_group && member
member . update_attributes! ( course_group_id : course_group . id )
normal_status ( 0 , " 加入成功 " )
end
end
# 将学生批量移动到某个分班
def transfer_to_course_group
ActiveRecord :: Base . transaction do
begin
course_group_id = params [ :course_group_id ] . to_i
# course_group_id为0意味着移动学生到未分班
if course_group_id != 0
course_group = CourseGroup . find_by! ( id : course_group_id , course_id : @course . id )
course_group_id = course_group . id
end
@course . students . where ( id : params [ :students ] . pluck ( :course_member_id ) ) . each do | student |
student . update_attributes! ( course_group_id : course_group_id )
end
normal_status ( 0 , " 操作成功 " )
rescue = > e
uid_logger ( e . message )
tip_exception ( " 操作失败 " )
raise ActiveRecord :: Rollback
end
end
end
# 从当前课堂删除学生
def delete_from_course
ActiveRecord :: Base . transaction do
begin
students = params [ :students ]
student_ids = [ ]
students . each do | student |
course_member = CourseMember . find_by ( id : student [ :course_member_id ] . to_i , course_id : @course . id )
if course_member . present?
member_teacher = CourseMember . find_by ( user_id : course_member . user_id , course_id : @course . id , role : % i [ CREATOR PROFESSOR ASSISTANT_PROFESSOR ] )
student_ids << course_member . user_id
course_member . destroy!
member_teacher . update_attributes ( is_active : 1 ) if member_teacher . present?
end
end
CourseDeleteStudentDeleteWorksJob . perform_later ( @course . id , student_ids ) if student_ids . present?
CourseDeleteStudentNotifyJob . perform_later ( @course . id , student_ids , current_user . id ) if student_ids . present?
normal_status ( 0 , " 操作成功 " )
rescue = > e
uid_logger ( e . message )
tip_exception ( " 操作失败 " )
raise ActiveRecord :: Rollback
end
end
end
# 搜索添加学生
def add_students_by_search
student_ids = [ ]
ActiveRecord :: Base . transaction do
user_ids = params [ :user_ids ]
course_group_id = params [ :course_group_id ] . to_i
if course_group_id != 0
course_group = CourseGroup . find ( course_group_id )
course_group_id = course_group . id
end
user_ids . each do | user_id |
existing_course_member = @course . course_members . find_by ( user_id : user_id . to_i )
new_student = CourseMember . new ( user_id : user_id . to_i , course_id : @course . id , course_group_id : course_group_id , role : 4 )
if existing_course_member . present?
if existing_course_member . STUDENT?
existing_course_member . update_attributes ( course_group_id : course_group_id )
else
new_student . is_active = 0 if existing_course_member . is_active
new_student . save!
student_ids << user_id
end
else
new_student . save!
student_ids << user_id
end
end
end
CourseAddStudentCreateWorksJob . perform_later ( @course . id , student_ids ) if student_ids . present?
TeacherInviteJoinCourseNotifyJob . perform_later ( current_user . id , @course . id , 10 , student_ids ) if student_ids . present?
normal_status ( 0 , " 添加成功 " )
end
# 获取历史课堂,即用户管理的所有课堂以及课堂下的分班(去除当前课堂)
def get_historical_courses
@courses = Course . where . not ( id : @course . id ) . joins ( :course_members ) .
where ( is_delete : 0 , course_members : { user_id : current_user . id , role : % i [ CREATOR PROFESSOR ASSISTANT_PROFESSOR ] } ) . includes ( :course_groups )
# @courses = Course.includes(:course_groups).where(id: current_user.course_members, is_delete: 0)
end
# 根据历史课堂的课堂id和分班id获取所有学生
def get_historical_course_students
course_id = params [ :course_id ]
course_group_id = params [ :course_group_id ]
@students = CourseMember . where ( course_id : course_id , role : % i [ STUDENT ] )
if course_group_id . present?
@students = @students . where ( course_group_id : course_group_id )
end
@students = @students . includes ( user : [ user_extension : :school ] )
@students_count = @students . size
end
# 导入创建分班
def create_group_by_importing_file
attachment_ids = [ ]
params [ :attachment_ids ] . each do | id |
attachment = Attachment . find ( id . to_i )
attachment_ids << attachment . id
end
associate_result = Attachment . associate_container ( attachment_ids , @course . id , @course . class )
return normal_status ( " 参数错误 " ) unless associate_result
attachment_ids . each do | attachment_id |
attachment = Attachment . find attachment_id
path = attachment . disk_directory
name = attachment . disk_filename
if name . split ( " . " ) . last == " xls "
begin
attachment_folder = edu_setting ( 'attachment_folder' )
full_path = " #{ attachment_folder } / #{ path } / #{ name } "
xls = Roo :: Spreadsheet . open ( full_path , extension : :xls )
worksheet = xls . sheet ( 0 )
rows = worksheet . last_row . to_i #最后一行数
if rows < 2
return normal_status ( - 1 , " 请按照模板格式导入 " )
else
group_count = 0
( 2 .. rows ) . each do | row |
name = worksheet . cell ( row , 1 ) . to_s
if @course . course_groups . where ( :name = > name ) . blank?
@course . course_groups << CourseGroup . new ( :name = > name , :position = > @course . course_groups_count + 1 )
group_count += 1
end
end
return normal_status ( " 已导入 #{ group_count } 个分班 " )
end
rescue = > e
uid_logger_error ( e . message )
normal_status ( - 1 , " 无法完成导入,原因:文件内容无法读取 " )
end
else
normal_status ( - 1 , " 只支持xls文件的导入 " )
end
end
end
# --- 学生列表相关API --- END
# 根据姓名和单位搜索用户
def search_users
name = params [ :name ]
school_name = params [ :school_name ]
# REDO:Extension
@users = User . where ( status : User :: STATUS_ACTIVE )
@users = @users . where ( laboratory_id : current_laboratory . id ) unless current_laboratory . main_site?
@users = @users . where ( " concat(users.lastname, users.firstname) like '% #{ name } %' " ) if name . present?
# REDO:Extension
@users = @users . joins ( user_extension : :school ) . where ( " schools.name like '% #{ school_name } %' " ) if school_name . present?
@users_count = @users . size
limit = params [ :limit ] || 20
page = params [ :page ] || 1
@users = @users . includes ( user_extension : :school ) . page ( page ) . per ( limit )
end
# 申请加入课堂
def apply_to_join_course
ActiveRecord :: Base . transaction do
begin
# 邀请码验证
return normal_status ( - 1 , " 邀请码不能为空 " ) if params [ :invite_code ] . blank?
invite_code = params [ :invite_code ]
course = Course . find_by ( invite_code : invite_code , is_delete : 0 , invite_code_halt : 0 , laboratory_id : current_laboratory . id )
course_group = CourseGroup . find_by ( invite_code : invite_code )
if course . blank?
return normal_status ( - 1 , " 邀请码无效 " ) if course_group . blank?
course = Course . find_by ( id : course_group . course_id , is_delete : 0 , invite_code_halt : 0 , laboratory_id : current_laboratory . id )
return normal_status ( - 1 , " 邀请码无效 " ) if course . blank?
end
return normal_status ( - 1 , " 课堂已结束,无法加入 " ) if course . is_end
# 实名认证和职业认证的身份判断
return normal_status ( - 2 , " 该课堂要求成员完成实名和职业认证 " ) if course . authentication &&
course . professional_certification && ( ! current_user . authentication && ! current_user . professional_certification )
return normal_status ( - 2 , " 该课堂要求成员完成实名认证 " ) if course . authentication && ! current_user . authentication
return normal_status ( - 2 , " 该课堂要求成员完成职业认证 " ) if course . professional_certification && ! current_user . professional_certification
# 身份验证
if params [ :professor ] . blank? && params [ :assistant_professor ] . blank? && params [ :student ] . blank?
return normal_status ( - 1 , " 请先选择身份 " )
end
if params [ :professor ] . present? && params [ :assistant_professor ] . present?
return normal_status ( - 1 , " 同一课堂不允许申请多个教师身份 " )
end
# 验证是否存在同学号的学生
# u_extension = current_user.user_extension
# if params[:student].present? && u_extension.student?
# same_student_id_users = UserExtension.where.not(user_id: current_user.id).where(student_id: u_extension.student_id, identity: %i[student], school_id: u_extension.school_id).pluck(:user_id)
# tip_exception("该课堂已存在同学号的学生,暂时无法加入,请联系老师") if course.students.exists?(user_id: same_student_id_users)
# end
# 创建学生身份
if params [ :student ] . present? && params [ :student ] . to_i == 1
existing_student = CourseMember . find_by ( course_id : course . id , role : % i [ STUDENT ] , user_id : current_user . id )
if existing_student . present?
# 如果在该课堂已经存在学生身份,且邀请码为分班邀请码,则将其直接加入分班
existing_student . update_attributes ( course_group_id : course_group . id ) if course_group . present?
else
correspond_teacher_exist = current_user . none_admin_teacher_of_course? course
new_student = CourseMember . new ( user_id : current_user . id , course_id : course . id , role : 4 )
new_student . is_active = 0 if correspond_teacher_exist
new_student . course_group_id = course_group . id if course_group . present?
new_student . save!
CourseAddStudentCreateWorksJob . perform_later ( course . id , [ current_user . id ] )
StudentJoinCourseNotifyJob . perform_later ( current_user . id , course . id )
end
student_role = 1
end
# 创建教师身份
if ( params [ :professor ] . present? && params [ :professor ] . to_i == 1 ) || ( params [ :assistant_professor ] . present? && params [ :assistant_professor ] . to_i == 1 )
teacher_already_exist = current_user . teacher_of_course_non_active? course
unless teacher_already_exist
existing_course_message = CourseMessage . find_by ( course_id : course . id , course_message_id : current_user . id ,
course_message_type : " JoinCourseRequest " , status : 0 )
if existing_course_message . blank?
course_message = CourseMessage . new ( course_id : course . id , user_id : course . tea_id , status : 0 ,
course_message_id : current_user . id , course_message_type : " JoinCourseRequest " ,
viewed : false )
if params [ :professor ] . present? && params [ :professor ] . to_i == 1
course_message . content = 2
role = 9
message = " 教师申请已提交,请等待审核 "
else
course_message . content = 3
role = 7
message = " 助教申请已提交,请等待审核 "
end
course_message . save!
# role = course_message.content == 2 ? '9' : '7' # 7:助教 9:教师
ApplyTeacherRoleJoinCourseNotifyJob . perform_later ( current_user . id , course . id , role )
# message = "#{course_message.content == 2 ? '教师' : '助教'}申请已提交,请等待审核"
else
message = " #{ existing_course_message . content == '2' ? '教师' : '助教' } 申请已提交,请等待审核 "
end
else
message = " 您已是课堂成员 "
end
teacher_role = 1
end
if teacher_role && student_role
render json : { status : 0 , message : message , course_id : course . id }
elsif student_role
render json : { status : 0 , message : " 加入成功 " , course_id : course . id }
else
normal_status ( message )
end
rescue = > e
uid_logger ( e . message )
tip_exception ( e . message )
raise ActiveRecord :: Rollback
end
end
end
def top_banner
@user = current_user
@switch_student = Course :: BUSINESS < @user_course_identity && @user_course_identity < Course :: STUDENT
@is_student = @user_course_identity == Course :: STUDENT
@course . increment! ( :visits )
end
def left_banner
@user = current_user
@is_teacher = @user_course_identity < Course :: ASSISTANT_PROFESSOR
@course_modules = @course . course_modules . where ( hidden : 0 )
@hidden_modules = @course . course_modules . where ( hidden : 1 )
@second_category_type = [ " shixun_homework " , " graduation " , " attachment " , " board " , " course_group " ]
end
def board_list
begin
@course = @board . course
@current_user = current_user
return normal_status ( 403 , " 你没有权限操作 " ) if ! @current_user . teacher_of_course? ( @course ) && ! @current_user . course_identity ( @current_user ) == 4
@boards = @course . boards
rescue Exception = > e
uid_logger ( e . message )
tip_exception ( " 获取数据失败 " )
raise ActiveRecord :: Rollback
end
end
def attahcment_category_list
@has_course_groups = @course . course_groups . exists?
@course_modules = @course . attachment_course_modules
end
def mine
@page = params [ :page ] || 1
@page_size = params [ :page_size ] || 15
@courses = Course . by_user ( current_user ) . hidden ( false ) . processing . not_deleted . by_keywords ( params [ :search ] ) . distinct
# @total_count = @courses.count
# offset = 0
# while offset < @total_count
#
# offset = offset + @page_size.to_i + 1
# @courses = @courses.offset(offset)
# end
@courses = @courses . page ( @page ) . per ( @page_size )
end
# 导出课堂信息
def export_couser_info
if params [ :export ] . present? && params [ :export ]
normal_status ( 0 , " 正在下载中 " )
else
set_export_cookies
course_info_to_xlsx @course
filename_ = " #{ current_user . real_name } _ #{ @course . name } _课堂信息_ #{ Time . now . strftime ( '%Y%m%d_%H%M%S' ) } "
render xlsx : " #{ format_sheet_name filename_ . strip } " , template : " courses/export_course_info.xlsx.axlsx " ,
locals : { course_info : @course_info }
end
end
# 导出活跃度
def export_member_act_score
search = params [ :search ] ? " #{ params [ :search ] . strip } " : " " #用户名或学生学号id搜索
group_id = params [ :group_id ] #分班的班级id
@all_members = @course . students
@all_members = @all_members . where ( course_group_id : group_id ) unless group_id . blank?
unless search . blank?
@all_members = @all_members . joins ( user : [ :user_extension ] ) . where ( 'concat(users.lastname, users.firstname) like ? or user_extensions.student_id like ?' , " % #{ search } % " , " % #{ search } % " )
end
if @all_members . size == 0
normal_status ( - 1 , " 课堂暂时没有学生 " )
elsif params [ :export ] . present? && params [ :export ]
normal_status ( 0 , " 正在下载中 " )
else
set_export_cookies
@all_members = student_act_score group_id , search
act_score_to_xlsx ( @all_members )
filename_ = " #{ current_user . real_name } _ #{ @course . name } _活跃度_ #{ Time . now . strftime ( '%Y%m%d_%H%M%S' ) } "
render xlsx : " #{ format_sheet_name filename_ . strip } " , template : " courses/export_member_act_score.xlsx.axlsx " ,
locals : { activity_level : @user_activity_level }
end
end
# 导出学生成绩
def export_member_scores_excel
ActiveRecord :: Base . transaction do
begin
@all_members = @course . students
search = params [ :search ] ? " #{ params [ :search ] . strip } " : " " #用户名或学生学号id搜索
if params [ :group_id ] . present?
group_ids = params [ :group_id ] . is_a? ( String ) ? [ params [ :group_id ] . to_i ] : params [ :group_id ] . map ( & :to_i )
@all_members = @all_members . where ( course_group_id : group_ids )
end
unless search . blank?
@all_members = @all_members . joins ( user : [ :user_extension ] ) . where ( 'concat(users.lastname, users.firstname) like ? or user_extensions.student_id like ?' , " % #{ search } % " , " % #{ search } % " )
end
if @all_members . length == 0
normal_status ( - 1 , " 课堂暂时没有学生 " )
elsif params [ :export ] . present? && params [ :export ]
normal_status ( 0 , " 正在下载中 " )
else
@c_homeworks = @course . homework_commons . homework_published . order ( " homework_commons.publish_time asc, homework_commons.created_at asc " )
@c_exercises = @course . exercises . is_exercise_published . order ( " exercises.publish_time asc, exercises.created_at asc " )
# @c_polls = @course.polls.publish_or_not.order("polls.publish_time asc, polls.created_at asc")
@c_tasks = @course . graduation_tasks . task_published . order ( " graduation_tasks.publish_time asc, graduation_tasks.created_at asc " )
set_export_cookies
member_to_xlsx ( @course , @all_members . includes ( user : :user_extension ) , @c_homeworks , @c_exercises , @c_tasks )
filename_ = " #{ current_user . real_name } _ #{ @course . name } _总成绩_ #{ Time . now . strftime ( '%Y%m%d_%H%M%S' ) } "
render xlsx : " #{ format_sheet_name filename_ . strip } " , template : " courses/export_member_scores_excel.xlsx.axlsx " ,
locals : { course_scores : @course_user_scores , shixun_works : @shixun_work_arrays ,
common_works : @common_work_arrays , group_works : @group_work_arrays , task_works : @task_work_arrays ,
exercise_works : @exercise_work_arrays }
end
rescue Exception = > e
uid_logger_error ( e . message )
tip_exception ( e . message )
raise ActiveRecord :: Rollback
end
end
end
# 计算课堂所有已发布的实训作业成绩
def calculate_all_shixun_scores
tip_exception ( - 1 , " 课堂已结束 " ) if @course . is_end
shixun_homeworks = @course . homework_commons . homework_published . where ( homework_type : 4 )
shixun_homeworks . includes ( :homework_challenge_settings , :published_settings , :homework_commons_shixun ) . each do | homework |
homework . update_homework_work_score
end
normal_status ( 0 , " 更新成功 " )
end
def search_slim
courses = current_user . manage_courses . not_deleted . processing
keyword = params [ :keyword ] . to_s . strip
if keyword . present?
courses = courses . where ( 'name LIKE ?' , " % #{ keyword } % " )
end
count = courses . count
courses = paginate ( courses )
render_ok ( count : count , courses : courses . select ( :id , :name ) . as_json )
end
def tasks_list
case params [ :container_type ]
when 'shixun_homework'
@tasks = @course . practice_homeworks
when 'common_homework'
@tasks = @course . normal_homeworks
when 'group_homework'
@tasks = @course . group_homeworks
when 'exercise'
@tasks = @course . exercises
when 'poll'
@tasks = @course . polls
when 'graduation_topic'
@tasks = @course . graduation_topics
when 'graduation_task'
@tasks = @course . graduation_tasks
when 'attachment'
@tasks = @course . attachments
else
tip_exception ( " 请指定任务类型 " )
end
end
def update_task_position
Rails . logger . info ( " # # # # # # # task_ids_length #{ params [ :task_ids ] . uniq . length } # # # # # # # # # task_count: #{ @tasks . count } " )
tip_exception ( " task_ids参数有误 " ) if params [ :task_ids ] . blank? || params [ :task_ids ] . uniq . length != @tasks . count
ActiveRecord :: Base . transaction do
begin
@tasks . each do | task |
position = params [ :task_ids ] . reverse . index ( task . id ) . to_i + 1
task . update_attributes! ( position : position )
end
normal_status ( 0 , " 移动成功 " )
rescue Exception = > e
uid_logger ( e . message )
tip_exception ( e . message )
raise ActiveRecord :: Rollback
end
end
end
private
# Use callbacks to share common setup or constraints between actions.
def set_course
@course = Course . find_by! ( id : params [ :id ] )
tip_exception ( 404 , " " ) if @course . is_delete == 1 && ! current_user . admin?
end
# Never trust parameters from the scary internet, only allow the white list through.
def course_params
params . require ( :course ) . permit ( :name , :class_period , :credit , :end_date , :is_public , :authentication , :professional_certification )
end
def validate_course_name
tip_exception ( " 课堂名称不能为空! " ) if params [ :course ] [ :name ] . blank?
if params [ :subject_id ] . blank? && @course . blank? || ( @course && @course . subject . blank? )
tip_exception ( " 课程名称不能为空! " ) if params [ :course_list_name ] . blank?
tip_exception ( " 课堂名称应以课程名称开头命名 " ) unless params [ :course ] [ :name ] . index ( params [ :course_list_name ] ) &&
params [ :course ] [ :name ] . index ( params [ :course_list_name ] ) == 0
else
@subject = @course . present? ? @course . subject : Subject . find_by! ( id : params [ :subject_id ] )
tip_exception ( " 开始时间不能为空 " ) if params [ :start_date ] . blank?
tip_exception ( " 结束时间不能为空 " ) if params [ :end_date ] . blank?
tip_exception ( " 结束时间必须晚于开始时间 " ) if strf_date ( params [ :end_date ] ) < = strf_date ( params [ :start_date ] )
tip_exception ( " 开始时间和结束时间不能早于往期开课时间 " ) if @course . nil? && @subject . max_course_end_date && strf_date ( params [ :start_date ] ) < = strf_date ( @subject . max_course_end_date )
validate_start_end_date if @course . present?
tip_exception ( " 开放课堂必须包含公告栏和在线学习模块 " ) unless params [ :course_module_types ] . include? ( " announcement " ) && params [ :course_module_types ] . include? ( " online_learning " )
end
tip_exception ( " 课堂所属单位不能为空! " ) if params [ :school ] . blank?
tip_exception ( " 请至少添加一个课堂模块 " ) if params [ :course_module_types ] . blank?
@school = School . find_by ( name : params [ :school ] . strip )
tip_exception ( " 所属单位不存在 " ) unless @school . present?
end
def validate_start_end_date
prev_course = @subject . courses . where ( " id < #{ @course . id } " ) . last
next_course = @subject . courses . where ( " id > #{ @course . id } " ) . first
tip_exception ( " 开始时间不能与往期开课时间重叠 " ) if prev_course && strf_date ( params [ :start_date ] ) < = strf_date ( prev_course . end_date )
tip_exception ( " 结束时间不能与后期开课时间重叠 " ) if next_course && strf_date ( params [ :end_date ] ) > = strf_date ( next_course . start_date )
end
# 超级管理员和课堂管理员的权限判断
def admin_allowed
unless @user_course_identity < Course :: PROFESSOR
tip_exception ( 403 , " .. " )
end
end
# 课堂教师的权限判断
def teacher_allowed
unless @user_course_identity < Course :: STUDENT
tip_exception ( 403 , " .. " )
end
end
# 课堂教师,课堂管理员以及超级管理员的权限判断
def teacher_or_admin_allowed
unless @user_course_identity < Course :: ASSISTANT_PROFESSOR
tip_exception ( 403 , " .. " )
end
end
def course_member_allowed
tip_exception ( 403 , " .. " ) if @user_course_identity > Course :: STUDENT
end
def course_tasks
case params [ :container_type ]
when 'shixun_homework'
@tasks = @course . practice_homeworks
when 'common_homework'
@tasks = @course . normal_homeworks
when 'group_homework'
@tasks = @course . group_homeworks
when 'exercise'
@tasks = @course . exercises
when 'poll'
@tasks = @course . polls
when 'graduation_topic'
@tasks = @course . graduation_topics
when 'graduation_task'
@tasks = @course . graduation_tasks
when 'attachment'
@tasks = @course . attachments
else
tip_exception ( " 请指定任务类型 " )
end
end
def validate_inform_params
tip_exception ( " 公告标题不能为空 " ) if params [ :name ] . blank?
tip_exception ( " 公告内容不能为空 " ) if params [ :description ] . blank?
end
# def find_container
# case params[:container_type]
# when 'shixun_homework', 'common_homework', 'group_homework'
# @task = HomeworkCommon.find_by(id: params[:container_id])
# when 'exercise'
# @task = Exercise.find_by(id: params[:container_id])
# when 'poll'
# @task = Poll.find_by(id: params[:container_id])
# when 'graduation_topic'
# @task = GraduationTopic.find_by(id: params[:container_id])
# when 'graduation_task'
# @task = GraduationTask.find_by(id: params[:container_id])
# when 'attachment'
# @task = Attachment.find_by(id: params[:container_id])
# else
# tip_exception("container_type参数有误")
# end
# end
def student_act_score group_id , search
sql_select = %Q{ SELECT cm.*,
( SELECT max ( student_id ) FROM user_extensions WHERE user_extensions . user_id = cm . user_id ) AS student_id ,
( SELECT count ( messages . id ) FROM messages join boards on messages . board_id = boards . id WHERE boards . course_id = #{@course.id}
AND messages . author_id = cm . user_id and messages . parent_id is null ) AS message_num ,
( SELECT count ( messages . id ) FROM messages join boards on messages . board_id = boards . id WHERE boards . course_id = #{@course.id}
AND messages . author_id = cm . user_id and messages . parent_id is not null ) AS message_reply_num ,
( SELECT count ( attachments . id ) FROM attachments WHERE container_id = #{@course.id} and container_type = "Course"
AND attachments . author_id = cm . user_id ) AS resource_num ,
( SELECT count ( jfm . id ) FROM journals_for_messages AS jfm , homework_commons hs WHERE jfm . jour_id = hs . id AND
jfm . user_id = cm . user_id and jfm . jour_type = " HomeworkCommon " and hs . course_id = #{@course.id}) AS homework_journal_num,
( SELECT COUNT ( gw . id ) FROM graduation_works AS gw , graduation_tasks AS gt WHERE gw . graduation_task_id = gt . id AND
gt . course_id = #{@course.id} AND gw.work_status != 0 AND gw.user_id = cm.user_id) AS graduation_num,
( SELECT COUNT ( ss . id ) FROM student_works AS ss , homework_commons AS hc WHERE ss . homework_common_id = hc . id AND
hc . course_id = #{@course.id} AND ss.work_status != 0 AND ss.user_id = cm.user_id) AS homework_num,
( SELECT COUNT ( eu . id ) FROM exercise_users AS eu , exercises WHERE eu . exercise_id = exercises . id AND exercises . course_id = #{@course.id}
AND eu . commit_status = 1 AND eu . user_id = cm . user_id ) AS exercise_num ,
( SELECT COUNT ( pu . id ) FROM poll_users AS pu , polls WHERE pu . poll_id = polls . id AND polls . course_id = #{@course.id}
AND pu . commit_status = 1 AND pu . user_id = cm . user_id ) AS poll_num
FROM course_members cm }
if search . present? && group_id . present?
sql_select += %Q{ join users on cm.user_id = users.id
join user_extensions ue on ue . user_id = users . id
WHERE cm . role = 4 and cm . course_id = #{@course.id} and cm.course_group_id = #{group_id} and
( concat ( users . lastname , users . firstname ) like '%#{search}%' or ue . student_id like '%#{search}%' ) }
elsif search . present?
sql_select += %Q{ join users on cm.user_id = users.id
join user_extensions ue on ue . user_id = users . id
WHERE cm . role = 4 and
( concat ( users . lastname , users . firstname ) like '%#{search}%' or ue . student_id like '%#{search}%' ) }
elsif group_id . present?
group_id = group_id . is_a? ( Array ) ? group_id . map ( & :to_i ) : [ group_id . to_i ]
sql_select += %Q{ WHERE cm.role = 4 and cm.course_id = #{ @course . id } and cm.course_group_id in ( #{ group_id . join ( " , " ) } ) }
else
sql_select += %Q{ WHERE cm.role = 4 and cm.course_id = #{ @course . id } }
end
act_scores = CourseMember . find_by_sql ( sql_select )
act_scores
end
def course_statistics course , max_exp , limit
max_rate = max_exp . nil? || max_exp == 0 ? 0 : 20 . 0 / max_exp
sql_select = %Q{ SELECT a.*, (message_num*0.2 + message_reply_num*0.1 + resource_num*0.5 + homework_journal_num*0.1 + graduation_num +
homework_num + exercise_num + poll_num * 0 . 7 + exercise_score * 0 . 7 + graduation_score * 0 . 7 + homework_score * 0 . 7 + exp * #{max_rate})
AS score from
( select cm . * , users . experience as exp ,
( SELECT count ( messages . id ) FROM messages join boards on messages . board_id = boards . id WHERE boards . course_id = #{course.id}
AND messages . author_id = cm . user_id and messages . parent_id is null ) AS message_num ,
( SELECT count ( messages . id ) FROM messages join boards on messages . board_id = boards . id WHERE boards . course_id = #{course.id}
AND messages . author_id = cm . user_id and messages . parent_id is not null ) AS message_reply_num ,
( SELECT count ( attachments . id ) FROM attachments WHERE container_id = #{course.id} and container_type = "Course"
AND attachments . author_id = cm . user_id ) AS resource_num ,
( SELECT count ( jfm . id ) FROM journals_for_messages AS jfm , homework_commons hs WHERE jfm . jour_id = hs . id AND
jfm . user_id = cm . user_id and jfm . jour_type = " HomeworkCommon " and hs . course_id = #{course.id}) AS homework_journal_num,
( SELECT COUNT ( gw . id ) FROM graduation_works AS gw , graduation_tasks AS gt WHERE gw . graduation_task_id = gt . id AND
gt . course_id = #{course.id} AND gw.work_status != 0 AND gw.user_id = cm.user_id) AS graduation_num,
( SELECT IFNULL ( sum ( gw . work_score ) , 0 ) FROM graduation_works AS gw , graduation_tasks AS gt WHERE gw . graduation_task_id = gt . id AND
gt . course_id = #{course.id} AND gw.work_status != 0 AND gw.user_id = cm.user_id) AS graduation_score,
( SELECT COUNT ( ss . id ) FROM student_works AS ss , homework_commons AS hc WHERE ss . homework_common_id = hc . id AND
hc . course_id = #{course.id} AND ss.work_status != 0 AND ss.user_id = cm.user_id) AS homework_num,
( SELECT IFNULL ( sum ( ss . work_score ) , 0 ) FROM student_works AS ss , homework_commons AS hc WHERE ss . homework_common_id = hc . id AND
hc . course_id = #{course.id} AND ss.work_status != 0 AND ss.user_id = cm.user_id) AS homework_score,
( SELECT COUNT ( eu . id ) FROM exercise_users AS eu , exercises WHERE eu . exercise_id = exercises . id AND exercises . course_id = #{course.id}
AND eu . commit_status = 1 AND eu . user_id = cm . user_id ) AS exercise_num ,
( SELECT IFNULL ( sum ( eu . score ) , 0 ) FROM exercise_users AS eu , exercises WHERE eu . exercise_id = exercises . id AND exercises . course_id = #{course.id}
AND eu . commit_status = 1 AND eu . user_id = cm . user_id ) AS exercise_score ,
( SELECT COUNT ( pu . id ) FROM poll_users AS pu , polls WHERE pu . poll_id = polls . id AND polls . course_id = #{course.id}
AND pu . commit_status = 1 AND pu . user_id = cm . user_id ) AS poll_num
FROM course_members cm join users on cm . user_id = users . id
WHERE cm . role = 4 and cm . course_id = #{course.id}) a ORDER BY score desc limit #{limit};
}
CourseMember . find_by_sql ( sql_select )
end
def course_work_scores course , sort , group_ids
sql_select = %Q{ SELECT a.*,
( exercise_score + graduation_score + common_score + practice_score + group_score ) AS score from
( select cm . * ,
( SELECT IFNULL ( sum ( gw . work_score ) , 0 ) FROM graduation_works AS gw , graduation_tasks AS gt WHERE gw . graduation_task_id = gt . id AND
gt . course_id = #{course.id} AND gw.work_status != 0 AND gw.user_id = cm.user_id) AS graduation_score,
( SELECT IFNULL ( sum ( ss . work_score ) , 0 ) FROM student_works AS ss , homework_commons AS hc WHERE ss . homework_common_id = hc . id AND
hc . course_id = #{course.id} AND ss.work_status != 0 AND ss.user_id = cm.user_id and hc.homework_type=1) AS common_score,
( SELECT IFNULL ( sum ( ss . work_score ) , 0 ) FROM student_works AS ss , homework_commons AS hc WHERE ss . homework_common_id = hc . id AND
hc . course_id = #{course.id} AND ss.work_status != 0 AND ss.user_id = cm.user_id and hc.homework_type=3) AS group_score,
( SELECT IFNULL ( sum ( ss . work_score ) , 0 ) FROM student_works AS ss , homework_commons AS hc WHERE ss . homework_common_id = hc . id AND
hc . course_id = #{course.id} AND ss.work_status != 0 AND ss.user_id = cm.user_id and hc.homework_type=4) AS practice_score,
( SELECT IFNULL ( sum ( eu . score ) , 0 ) FROM exercise_users AS eu , exercises WHERE eu . exercise_id = exercises . id AND exercises . course_id = #{course.id}
AND eu . commit_status = 1 AND eu . user_id = cm . user_id ) AS exercise_score
FROM course_members cm join users on cm . user_id = users . id
WHERE cm . role = 4 and cm . course_id = #{course.id}
}
sql_select += %Q{ and cm.course_group_id in ( #{ group_ids . join ( " , " ) } ) } if group_ids . present?
sql_select += %Q{ ) a ORDER BY score #{ sort } ; }
course_members = CourseMember . find_by_sql ( sql_select )
course_members
end
def course_act_scores course , group_ids
sql_select = %Q{ SELECT a.*,
( message_num * 2 + message_reply_num + resource_num * 5 + homework_journal_num + graduation_num * 10 + homework_num * 10 + exercise_num * 10 + poll_num * 7 ) AS score from
( select cm . * ,
( SELECT count ( messages . id ) FROM messages join boards on messages . board_id = boards . id WHERE boards . course_id = #{course.id}
AND messages . author_id = cm . user_id and messages . parent_id is null ) AS message_num ,
( SELECT count ( messages . id ) FROM messages join boards on messages . board_id = boards . id WHERE boards . course_id = #{course.id}
AND messages . author_id = cm . user_id and messages . parent_id is not null ) AS message_reply_num ,
( SELECT count ( attachments . id ) FROM attachments WHERE container_id = #{course.id} and container_type = "Course"
AND attachments . author_id = cm . user_id ) AS resource_num ,
( SELECT count ( jfm . id ) FROM journals_for_messages AS jfm , homework_commons hs WHERE jfm . jour_id = hs . id AND
jfm . user_id = cm . user_id and jfm . jour_type = " HomeworkCommon " and hs . course_id = #{course.id}) AS homework_journal_num,
( SELECT COUNT ( gw . id ) FROM graduation_works AS gw , graduation_tasks AS gt WHERE gw . graduation_task_id = gt . id AND
gt . course_id = #{course.id} AND gw.work_status != 0 AND gw.user_id = cm.user_id) AS graduation_num,
( SELECT COUNT ( ss . id ) FROM student_works AS ss , homework_commons AS hc WHERE ss . homework_common_id = hc . id AND
hc . course_id = #{course.id} AND ss.work_status != 0 AND ss.user_id = cm.user_id) AS homework_num,
( SELECT COUNT ( eu . id ) FROM exercise_users AS eu , exercises WHERE eu . exercise_id = exercises . id AND exercises . course_id = #{course.id}
AND eu . commit_status = 1 AND eu . user_id = cm . user_id ) AS exercise_num ,
( SELECT COUNT ( pu . id ) FROM poll_users AS pu , polls WHERE pu . poll_id = polls . id AND polls . course_id = #{course.id}
AND pu . commit_status = 1 AND pu . user_id = cm . user_id ) AS poll_num
FROM course_members cm join users on cm . user_id = users . id
join user_extensions ue on ue . user_id = users . id
WHERE cm . role = 4 and cm . course_id = #{course.id}
}
sql_select += %Q{ and cm.course_group_id in ( #{ group_ids . join ( " , " ) } ) } if group_ids . present?
sql_select += %Q{ ) a ORDER BY score desc; }
course_members = CourseMember . find_by_sql ( sql_select )
course_members
end
end