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.
pgfqe6ch8/app/controllers/managements_controller.rb

4123 lines
168 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# encoding: utf-8
class ManagementsController < ApplicationController
before_filter :require_admin
layout 'base_management'
include ManagementsHelper
include SortHelper
include UsersHelper
include ApplicationHelper
include AvatarHelper
include ShixunsHelper
helper :files
if RUBY_PLATFORM =~ /linux/
require 'simple_xlsx_reader'
require 'roo-xls'
end
CODES = %W(2 3 4 5 6 7 8 9 A B C D E F G H J K L N M O P Q R S T U V W X Y Z)
# 工程认证视频导入模板
def ec_template
@template = EcTemplate.where(nil)
end
def add_template
logger.info("#############################{params}")
EcTemplate.create(:name => params[:name].strip)
@template = EcTemplate.where(nil)
end
def training_2018
@search = params[:search]
@training_type = params[:training_type]
@pay_type = params[:pay_type]
@page = params[:page] || 1
@status = params[:status]
if User.current.admin?
@trainings = Training.includes(:training_payinfo)
if params[:search] && params[:search].strip != ""
@trainings = @trainings.where("trainings.name like '%#{params[:search]}%'")
end
if params[:training_type] && params[:training_type].to_i != -1
@trainings = @trainings.where("training_type = #{params[:training_type]}")
end
if params[:pay_type] && params[:pay_type].to_i != -1
@trainings = @trainings.where("training_payinfos.pay_type = #{params[:pay_type]}")
end
if params[:status] && params[:status].to_i != -1
@trainings = @trainings.where("training_payinfos.status = #{params[:status]}")
end
@page = params[:page] || 1
@all_trainings = @trainings.reorder("trainings.created_at desc")
@trainings = paginateHelper @trainings.reorder("trainings.created_at desc"), 50
else
render_403
end
respond_to do |format|
format.js
format.html
format.xls{
time = Time.now.strftime("%Y%m%d")
filename = "#{time}培训会报名列表.xls"
send_data(training_2018_xls(@all_trainings), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
def update_pay_status
if User.current.admin? || User.current.id == 1
@training = Training.where(:id => params[:training]).first
if @training
@training.training_payinfo.update_attributes(:status => TrainingPayinfo::Status_Payed)
if @training.phone.present?
Trustie::Sms.send(mobile: @training.phone.to_s, send_type: "training_pay", user_name: @training.name)
end
end
else
render_403
end
end
def mul_test
@menu_type = 3
@sub_type = 9
@m_tests = MulTest.where(nil)
@m_tests_count = @m_tests.count
@m_tests_pages = Paginator.new @m_tests_count, 20, params['page'] || 1
@offset ||= @m_tests_pages.offset
@m_tests = paginateHelper @m_tests, 20
respond_to do |format|
format.js
format.html
end
end
def mul_statics
@m_tests = MulTest.all.group_by{|o|[o.num, o.shixun_id]}
# @m_tests_count = @m_tests.count
# @m_tests_pages = Paginator.new @m_tests_count, 20, params['page'] || 1
# @offset ||= @m_tests_pages.offset
# @m_tests = paginateHelper @m_tests, 20
end
def update_shixun_usescope
shixun = Shixun.where(:id => params[:shixun_id]).first
shixun.update_column(:use_scope, params[:use_scope].to_i)
render :json => {status: "success"}
end
#用户修改
def myshixuns
@menu_type = 3
@sub_type = 8
@g = Gitlab.client
if params[:search]
myshixun_id = Game.where(:identifier => params[:search]).pluck(:myshixun_id)
@myshixuns = Myshixun.where(:id => myshixun_id).includes(:shixun)
else
@myshixuns = Myshixun.where("0=0").includes(:shixun)
end
@myshixuns_count = @myshixuns.count
limit = 20
@myshixuns_pages = Paginator.new @myshixuns_count, limit, params['page'] || 1
@offset ||= @myshixuns_pages.offset
@myshixuns = paginateHelper @myshixuns, limit
respond_to do |format|
format.js
format.html
end
end
def myshixun_info
user_id = User.where(:login => params[:login].strip).pluck(:id).first
shixun_id = Shixun.where(:identifier => params[:shixun_id].strip).pluck(:id).first
myshixun = Myshixun.where(:user_id => user_id, :shixun_id => shixun_id).first
game = myshixun.current_task
@game_url = Setting.protocol + "://" + Setting.host_name + "/tasks/#{game.identifier}"
@git_url = Redmine::Configuration['gitlab_address']+"/"+myshixun.git_url
end
def anomaly_detection
end
def account
@user = User.find(params[:user_id])
begin
if request.post?
@user.nickname = params[:nickname]
@user.lastname = params[:lastname]
@user.firstname = ""
@user.mail = params[:mail].strip == "" ? nil : params[:mail]
@user.phone = params[:phone].strip == "" ? nil : params[:phone]
#@user.password = params[:new_password]
# if params[:new_password].strip != "" && params[:new_password_confirmation].strip != ""
# @user.password, @user.password_confirmation = params[:new_password], params[:new_password_confirmation]
# end
@se = @user.extensions
@se.school_id = params[:occupation]
@se.department_id = params[:department_id]
@se.gender = params[:sex]
@se.location = params[:province] if params[:province]
@se.location_city = params[:city] if params[:city]
@se.identity = params[:identity].to_i if params[:identity]
if @se.identity == 0
@se.technical_title = params[:te_technical_title] if params[:te_technical_title]
@se.student_id = nil
elsif @se.identity == 1
@se.student_id = params[:no] if params[:no]
@se.technical_title = nil
elsif @se.identity == 2
@se.technical_title = params[:pro_technical_title] if params[:pro_technical_title]
@se.student_id = nil
end
@se.brief_introduction = params[:brief_introduction]
@user.save
@se.save
us = UsersService.new
@user = us.change_password params.merge(:current_user_id => @user.id)
# if @user.save && @se.save
# reward_grade(@user, @user.id, 'Account', 500)
# # 头像保存
# FileUtils.mv diskfile1, diskfile, force: true if File.exist? diskfile1
# @user.pref.save
# @user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
# set_language_if_valid @user.language
# flash[:notice] = l(:notice_account_updated)
# return
# else
# # @user.login = lg
# end
end
# 不管前面是否有异常,如果文件已存在就删除
ensure
end
# @setting_type = 1
redirect_to update_user_managements_path(:user => @user)
end
# 获取镜像
def pull_mirror
#params[:jsonMirrorDetails] = '{"images":[{"imageID":"2367ee7a7d4c","name":"octave-novnc:v1.0"}, {"imageID":"1b9cfba2c4dd","name":"jfinal-mysql55:v1.0"}]}'
ActiveRecord::Base.transaction do
begin
shixun_tomcat = Redmine::Configuration['shixun_tomcat']
params = {}
uri = "#{shixun_tomcat}/bridge/docker/images"
res = uri_exec uri, params
if (res && res['code'] != 0)
raise("Pull mirror the repository exception")
end
mirrors = res["images"]
images = [] # 中间层镜像名称的数组
if mirrors.present?
mirrors.each do |mirror|
mirror = JSON.parse(mirror)
match_rep_mirror_name = MirrorRepository.where(:name => mirror['imageName']).first
match_rep_mirror_id = MirrorRepository.where(:mirrorID => mirror['imageID']).first
images << mirror['imageName']
if match_rep_mirror_name.blank? && match_rep_mirror_id.blank?
# 镜像不存在、创建镜像
new_mirror = MirrorRepository.create!(:mirrorID => mirror['imageID'], :name => mirror['imageName'])
MirrorOperationRecord.create!(:mirror_repository_id => new_mirror.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 0, :user_id => -1)
elsif match_rep_mirror_name.present? && match_rep_mirror_id.blank?
# 镜像ID被修改
match_rep_mirror_name.update_attributes(:status => 2)
MirrorOperationRecord.create!(:mirror_repository_id => match_rep_mirror_name.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 1, :user_id => -1)
elsif match_rep_mirror_name.blank? && match_rep_mirror_id.present?
# 镜像名称被修改
match_rep_mirror_id.update_attribute(:status, 3)
MirrorOperationRecord.create!(:mirror_repository_id => match_rep_mirror_id.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 2, :user_id => -1)
end
end
end
# 判断中间层镜像是否被删除
edu_mirrors = MirrorRepository.all
edu_mirrors.each do |mirror|
if(images.index(mirror.try(:name)).nil? && mirror.try(:name).present?)
mirror.update_attribute(:status, 4)
MirrorOperationRecord.create!(:mirror_repository_id => mirror.id, :mirror_id => mirror.try(:mirrorID), :mirror_name => mirror.name, :status => 3, :user_id => -1)
end
end
# end
redirect_to mirror_repository_managements_path
rescue Exception => e
logger.error("pull_mirror error: #{e}")
raise ActiveRecord::Rollback
end
end
end
# 验证镜像名是否重复
# 判断依据:主类别和小类别可以同名;主类别和小类别各自之间
def check_mirror_name
random = CODES.sample(8).join
mirror_count = MirrorRepository.where("type_name = ? and id != ? and main_type =?", params[:type_name], params[:mirror_id], params[:main_type].to_i).count
check = (mirror_count > 0 ? true : false)
render :json => {check: check, random: random}
end
# 中间层与edu镜像不一致时选择镜像一个可用的版本
def choose_mirror
@mirror = MirrorRepository.find(params[:mirror_id])
@new_mirror = MirrorOperationRecord.where(:mirror_repository_id => @mirror.id, :status => 1, :user_id => -1).first
respond_to do |format|
format.js
end
end
# flag: 0 更新新ID1 回退
# old_id: 平台保存的ID
# change_id 用户修改的新ID
# 选择镜像后向中间层updateImage flag: 0 更新新ID1 回退镜像
def choose_update_mirror
old_id = params[:id]
change_id = params[:mirror_id]
flag = (old_id == change_id ? 1 : 0)
ActiveRecord::Base.transaction do
begin
mirror = MirrorRepository.where(:mirrorID => old_id).first
if mirror.blank?
raise("choose_update_mirror exception")
end
shixun_tomcat = Redmine::Configuration['shixun_tomcat']
params = {imageName: mirror.name, imageID: old_id, flag: flag}
uri = "#{shixun_tomcat}/bridge/docker/updateImage"
res = uri_exec uri, params
if (res && res['code'] != 0)
raise("choose_update_mirror exception")
end
if flag == 0
mirror.update_attributes(:mirrorID => change_id, :status => 0)
# 用户操作的的行为需要记录 user_id 中间层操作的行为user_id = -1
MirrorOperationRecord.create!(:mirror_repository_id => mirror.id, :mirror_id => change_id, :mirror_name => mirror.name, :status => 1, :user_id => User.current.id, :old_tag => old_id, :new_tag => change_id)
else
mirror.update_attribute(:status, 0)
end
respond_to do |format|
format.js{ redirect_to mirror_repository_managements_path(:reaction => "choose_update_mirror")}
end
#format.js{ redirect_to mirror_repository_managements_path(:reaction => "choose_update_mirror")}
rescue Exception => e
logger.error("choose_update_mirror error: #{e}")
raise ActiveRecord::Rollback
end
end
end
# 搜索镜像
def mirror_search
@scope = []
if params[:q] && params[:q].lstrip.rstrip != ""
@scope = MirrorRepository.where("name like ?", "%#{params[:q]}%").map(&:name)
end
respond_to do |format|
format.js
end
end
# 镜像管理
# REDO: images Get请求不能用Post
def mirror_repository
@menu_type = 3
@sub_type = 5
@reaction = params[:reaction] # 如果是局部刷新调用,不需要拉取镜像
ActiveRecord::Base.transaction do
begin
# 重新定向或翻页不需要拉取镜像
if @reaction.nil? && @_params['page'].nil?
shixun_tomcat = Redmine::Configuration['shixun_tomcat']
uri = "#{shixun_tomcat}/bridge/docker/images"
res = get_url_exec uri
if (res && res['code'] != 0)
raise("Pull mirror the repository exception")
end
mirrors = res["images"] # 主节点的所有镜像
sync_mirrors = res['imagesNotSync'] # 子节点镜像异常(主节点有,而子节点却没同步/异常)
images = [] # 中间层镜像名称的数组
if sync_mirrors.present?
sync_mirrors.each do |mirror|
mirror = JSON.parse(mirror)
match_rep_mirror_name = MirrorRepository.where(:name => mirror['imageName']).first
# match_rep_mirror_id = MirrorRepository.where(:mirrorID => mirror['imageID']).first
if match_rep_mirror_name.present? && match_rep_mirror_name.status == 1
match_rep_mirror_name.update_attribute(:status, 5)
MirrorOperationRecord.create!(:mirror_repository_id => match_rep_mirror_name.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 4, :user_id => -1)
end
end
end
if mirrors.present?
mirrors.each do |mirror|
mirror = JSON.parse(mirror)
match_rep_mirror_name = MirrorRepository.where(:name => mirror['imageName']).first
match_rep_mirror_id = MirrorRepository.where(:mirrorID => mirror['imageID']).first
images << mirror['imageName']
if match_rep_mirror_name.blank?
# 镜像不存在、创建镜像
new_mirror = MirrorRepository.create!(:mirrorID => mirror['imageID'], :name => mirror['imageName'])
MirrorOperationRecord.create!(:mirror_repository_id => new_mirror.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 0, :user_id => -1)
elsif (match_rep_mirror_name.present? && (mirror['imageID'] != match_rep_mirror_name.mirrorID))
# 镜像ID被修改
match_rep_mirror_name.update_attributes(:status => 2)
MirrorOperationRecord.create!(:mirror_repository_id => match_rep_mirror_name.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 1, :user_id => -1)
elsif match_rep_mirror_name.blank? && match_rep_mirror_id.present?
# 镜像名称被修改
match_rep_mirror_id.update_attribute(:status, 3)
MirrorOperationRecord.create!(:mirror_repository_id => match_rep_mirror_id.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 2, :user_id => -1)
end
end
end
# 判断中间层镜像是否被删除
edu_mirrors = MirrorRepository.all
edu_mirrors.each do |mirror|
if(images.index(mirror.try(:name)).nil? && mirror.try(:name).present?)
mirror.update_attribute(:status, 4)
MirrorOperationRecord.create!(:mirror_repository_id => mirror.id, :mirror_id => mirror.try(:mirrorID), :mirror_name => mirror.name, :status => 3, :user_id => -1)
end
end
# end
end
@error_mirrors = MirrorRepository.where(:status => 5)
@menu_type = 3
@sub_type = 4
@mirrors = MirrorRepository.reorder("status desc, main_type desc, type_name asc")
@mirrors_count = @mirrors.count
@limit = 20
@page = (@_params['page'] || 1).to_i
@mirrors_pages = Paginator.new @mirrors_count, @limit, @page
@offset ||= @mirrors_pages.offset
@mirrors = paginateHelper @mirrors, @limit
respond_to do |format|
format.js
format.html
end
rescue Exception => e
logger.error("pull_mirror error: #{e}")
raise ActiveRecord::Rollback
end
end
end
# 迁移数据与脚本
# eg: shixun_id 字符类型。egshixun_id=61,71
# res['script'] tpm的模板
# res['template'] 标准模板
def migrate_data_and_script
ActiveRecord::Base.transaction do
begin
if params[:shixun_id]
shixuns = Shixun.where(:id => params[:shixun_id].split(","))
else
shixuns = Shixun.where(nil)
end
shixuns.find_each do |shixun|
main_miiror_name, child_miiror_name, secend_miiror_name = "", "", ""
case shixun.language
when 'C', 'C++'
main_miiror_name = 'C/C++'
when 'MySQL/Java'
main_miiror_name = 'Java'
child_miiror_name = 'Mysql'
when 'MySQL/Python3.6'
main_miiror_name = 'Python3.6'
child_miiror_name = 'Mysql'
when 'PHP/Web'
main_miiror_name = 'PHP'
child_miiror_name = 'Mysql'
secend_miiror_name = 'Web'
when 'Golang'
main_miiror_name ='Go'
when 'Html'
main_miiror_name = 'Python3.6'
child_miiror_name = 'Html'
else
main_miiror_name = shixun.language
end
main_miiror = MirrorRepository.where(:type_name => main_miiror_name).first
child_miiror = MirrorRepository.where(:type_name => child_miiror_name).first if child_miiror_name.present?
secend_miiror = MirrorRepository.where(:type_name => secend_miiror_name).first if child_miiror_name.present?
# 删除实训的关联,重新迁移
shixun.shixun_mirror_repositories.delete_all if shixun.mirror_repositories.present?
if main_miiror.present?
ShixunMirrorRepository.create!(:shixun_id => shixun.id, :mirror_repository_id => main_miiror.id)
else
MirrorMigrateError.create(:shixun_id => shixun.id, :game_info => "MainMirror")
logger.error("main_miiror is miss,shixun_id:#{shixun.id}")
end
ShixunMirrorRepository.create!(:shixun_id => shixun.id, :mirror_repository_id => child_miiror.id) if child_miiror.present?
ShixunMirrorRepository.create!(:shixun_id => shixun.id, :mirror_repository_id => secend_miiror.id) if secend_miiror.present?
params = {gameInfo: shixun.gameInfo}
# 根据旧版代码生成新的脚本
uri = "http://106.75.96.108:8890/bridge/dataTransfer/transferTPMScript"
res = uri_exec uri, params
if (res && res['code'] != 0)
logger.error("migrate_data_and_script 8890 exception;tpmID:#{shixun.id}")
MirrorMigrateError.create!(:shixun_id => shixun.id, :game_info => shixun.gameInfo)
end
template_script = tran_base64_decode64(res['template']) # 标准模板,一类语言一种
logger.error("##################################game_info: #{shixun.gameInfo}") if template_script.blank?
shixun.update_column(:evaluate_script, template_script)
main_miiror.update_column(:script_template, template_script) if main_miiror.present?
end
# 监测同步失败的实训
@ids = Shixun.all.map(&:id) - ShixunMirrorRepository.all.map(&:shixun_id)
respond_to do |format|
format.js
end
rescue Exception => e
render :json => {:data => "#{e}"}
logger.error("migrate_data_and_script error: #{e}")
raise ActiveRecord::Rollback
end
end
end
def modify_script
@mirror = MirrorRepository.find(params[:mirror_id])
if params[:script_template].present?
@mirror.update_attribute(:script_template, params[:script_template])
redirect_to mirror_repository_managements_path
return
end
respond_to do |format|
format.html{render :layout => "base_edu"}
end
end
def mirror_replace
@mirror_id = params[:id]
@mirror_name = params[:name]
end
# 修改此方法慎重:此方法只针对同一镜像出现两条记录,最终需要合并成一条
# 合并原则:把新的记录合并到老的记录中
# original_mirror表示被更新对象即历史老记录
# current_mirror表示新增镜像一般需要被替换掉替换成功后删除删除完成后
# 后台人员需要删除对应的镜像记录
def mirror_replace_update
begin
original_mirror = MirrorRepository.find(params[:original_mirror_id])
current_mirror = MirrorRepository.where(:name => params[:mirror_name]).first
original_mirror.update_attributes!(:name => params[:mirror_name], :mirrorID => current_mirror.mirrorID)
current_mirror.delete!
rescue Exception => e
logger.error(e)
end
end
# 职业路径列表
def career_list
@menu_type = 13
@careers =
if params[:search]
Career.includes(career_stages: [career_stage_subjects: :subject]).where("careers.name like '%#{params[:search]}%'").order("created_at desc")
else
Career.includes(career_stages: [career_stage_subjects: :subject]).order("created_at desc")
end
respond_to do |format|
format.js
format.html
end
end
# 发布职业路径
def published_career
career = Career.find(params[:id])
career.update_attribute(:status, true)
@careers = Career.includes(career_stages: [career_stage_subjects: :subject]).order("created_at desc")
end
# 删除职业路径
def delete_career
career = Career.find params[:id]
career.destroy
@careers = Career.includes(career_stages: [career_stage_subjects: :subject]).order("created_at desc")
end
# 工程认证专业信息目录
def major_information
@disciplines = EcDiscipline.includes(ec_discipline_firsts: [:ec_majors]).order("ec_disciplines.code asc")
end
# 认证单位列表
def auth_school
@schools = School.where(:ec_auth => 1).order("updated_at desc")
end
# 工程认证单位列表搜索学校
def search_school
@schools = School.where("ec_auth != 1 and name like '%#{params[:name]}%'").limit(10)
end
# 添加认证学校
def add_school
School.where(:id => params[:school_ids]).update_all(:ec_auth => 1)
render :json => {status: 1}
end
# 搜索用户
def search_manager
user_ids = EcSchoolUser.where(:school_id => params[:school_id]).pluck(:user_id)
user_ids = user_ids.present? ? user_ids.join(",") : -1
@users = User.where("concat(lastname, firstname) like '%#{params[:name]}%' and id not in(#{user_ids})").limit(10)
end
# 添加认证学校管理员
def add_manager
user_ids = params[:user_ids]
school_id = params[:school_id]
user_ids.each do |id|
EcSchoolUser.create(:user_id => id, :school_id => school_id)
end
render :json => {status: 1}
end
# 删除学校管理员
def remove_manager
manager = EcSchoolUser.where(:school_id => params[:school_id], :user_id => params[:user_id]).first
manager.destroy
end
# 删除认证学校
def remove_auth_school
school = School.find params[:school_id]
school.update_column(:ec_auth, 0)
school.ec_school_users.delete_all
end
# 工程认证: 毕业要求通用标准
def graduation_standard
@standards = EcGraduationStandard.all
end
# 创建通用标准
def create_standard
id = params[:id].to_i
content = params[:content]
if id == -1
EcGraduationStandard.create(:content => content)
else
standard = EcGraduationStandard.find params[:id]
standard.update_attribute(:content, content)
end
@standards = EcGraduationStandard.all
end
def add_mirror_type
data = {result: 0}
if params[:name]
if MirrorType.where(:name => params[:name]).count == 0
new_type = MirrorType.new(:user_id => User.current.id, :name => params[:name])
if new_type.save
data[:result] = 1
end
else
data[:result] = 2
end
end
render :json => data
end
def modify_mirror
@mirror = MirrorRepository.find params[:mirror_id]
@mirror_types = MirrorType.where(nil)
end
def search_mirror_type
data = {mirror_types: []}
search = params[:search]
MirrorType.where("name like '%#{search}%'").each do |mirror_type|
option = []
option << mirror_type.name.to_s
option << mirror_type.id
data[:mirror_types] << option
end
render :json => data
end
def create_mirror
MirrorRepository.create(:type_name => params[:type_name], :main_type => params[:mirror_type], :description => params[:description], :status => params[:status].to_i)
respond_to do |format|
format.js{redirect_to mirror_repository_managements_path(:reaction => "create_mirror")}
end
end
# 更新实训从未发布到发布需要syncImage同步镜像
def update_mirror
ActiveRecord::Base.transaction do
begin
@mirror = MirrorRepository.find(@_params[:mirror_id])
if @_params[:status].to_i == 1 && @mirror.status != 1
shixun_tomcat = Redmine::Configuration['shixun_tomcat']
params = {imageName: @mirror.name}
# 主从节点同步镜像
uri = "#{shixun_tomcat}/bridge/docker/syncImage"
res = uri_exec uri, params
if (res && res['code'] != 0)
raise("Synchronize Mirror exception")
end
end
if @_params[:type_name] != @mirror.type_name
MirrorOperationRecord.create!(:mirror_repository_id => @mirror.id, :status => 5, :user_id => User.current.id, :old_tag => @mirror.type_name, :new_tag => @_params[:type_name])
elsif @_params[:status].to_i != @mirror.status
MirrorOperationRecord.create!(:mirror_repository_id => @mirror.id, :status => 6, :user_id => User.current.id, :old_tag => @mirror.status, :new_tag => @_params[:status])
end
@mirror.update_attributes(:description => @_params[:description], :status => @_params[:status], :main_type => @_params[:mirror_type],
:type_name => @_params[:type_name], :resource_limit => @_params[:mirror_resource_limit], :cpu_limit => @_params[:mirror_cpu_limit],
:memory_limit => @_params[:mirror_memory_limit], :time_limit => @_params[:mirror_time_limit])
@index = MirrorRepository.order("created_at desc").map(&:id).index(@mirror.id)
respond_to do |format|
format.js
end
rescue Exception => e
logger.error("update_mirror error: #{e}")
raise ActiveRecord::Rollback
end
end
end
def delete_mirror
mirror = MirrorRepository.find params[:mirror_id]
mirror.destroy
respond_to do |format|
format.js{redirect_to mirror_repository_managements_path(:reaction => "delete_mirror")}
end
end
# 用户修改界面
def update_user
@menu_type = 7
@sub_type = 1
# @next_type = 1
if params[:flag]
applied_message = AppliedMessage.where(:id => params[:applied_message_id]).first
applied_message.update_attribute(:viewed, true)
end
@user = User.find(params[:user])
# 创建实训
@create_num = (@user == User.current ? Shixun.where(:user_id => @user).count : Shixun.where(:user_id => @user).visible.count)
# 创建课堂
@create_courses_count = @user.courses.not_deleted_not_end.select{ |course| @user.has_teacher_role(course)}.count
# 我的所有课程数
@all_courses_count = @user.courses.not_deleted_not_end.count
# 参与课堂
@join_courses_count = @all_courses_count - @create_courses_count
# 我合作的实训数
coop_id = Shixun.find_by_sql("select shixun_id from shixun_members where user_id=#{@user.id} and role = 2").map(&:shixun_id) # 合作者的实训id
@cooperative_num = Shixun.where(:id => coop_id).count
# 我挑战的实训数
ch_id = Shixun.find_by_sql("select id from shixuns where id in (select shixun_id from myshixuns where user_id = #{@user.id})")
@challenge_num = Shixun.where(:id => ch_id).count
#参与实训
@join_shixuns = @cooperative_num + @challenge_num
# 我的关注
watch_query = User.watched_by(@user.id)
@user_watchlist_count = watch_query.count()
# 我的粉丝
fan_query = @user.watcher_users
@user_fanlist_count = fan_query.count()
end
# 实训留言
def shixun_feedback
@menu_type = 9
@sub_type = 1
@discusses = Discuss.where(:dis_type => "Shixun").reorder("created_at desc")
@discusses_count = @discusses.count
@limit = 20
@is_remote = true
@page = (params['page'] || 1).to_i
@discusses_pages = Paginator.new @discusses_count, @limit, @page
@offset ||= @discusses_pages.offset
@discusses = paginateHelper @discusses, @limit
respond_to do |format|
format.js
format.html
end
end
# 实训反馈
def shixun_feedback_message
@menu_type = 8
@sub_type = 2
@discusses = Discuss.where(:dis_type => "Shixun").reorder("created_at desc")
@discusses_count = @discusses.count
@limit = 20
@is_remote = true
@page = (params['page'] || 1).to_i
@discusses_pages = Paginator.new @discusses_count, @limit, @page
@offset ||= @discusses_pages.offset
@discusses = paginateHelper @discusses, @limit
respond_to do |format|
format.js
format.html
end
end
def evaluate_recod_time
eva = EvaluateRecord.find(params[:record_id])
@consume_time = eva.consume_time
@student_work = eva.student_work
@file_update = eva.file_update
@git_pull = eva.git_pull
@create_pod = eva.create_pod
@pod_execute = eva.pod_execute
@test_cases = eva.test_cases
@return_back = eva.return_back
@brige = eva.brige
@front_js = eva.front_js
end
# 评测时间列表
def evaluate_records
shixun_tomcat = Redmine::Configuration['shixun_tomcat']
uri = "#{shixun_tomcat}/bridge/monitor/getPodsInfo"
res = uri_exec uri, params
if res['code'] == 0
@pod_num = res['sum']
@pod_dis = JSON.parse(res['distr']) if res['distr'].present?
end
@search = params[:search] # 搜索字
@keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/课程名搜索
if "u_name" == @keyword
if @search.blank?
@evaluate_recods = EvaluateRecord.where("0=0")
else
user_id = User.where("concat(lastname, firstname) like '%#{@search}%'")
@evaluate_recods = EvaluateRecord.joins("join users u on evaluate_records.user_id = u.id").where("concat(u.lastname, u.firstname) like '%#{@search}%'")
end
else
school_id = School.where("name like '%#{@search}%'").map(&:id)
user_id = UserExtensions.where(:school_id => school_id).map(&:user_id)
@evaluate_recods = EvaluateRecord.where(:user_id => user_id)
end
@evaluate_recods_count = @evaluate_recods.count
@page = (params['page'] || 1).to_i
@limit = 20
@is_remote = true
@evaluate_recods_pages = Paginator.new @evaluate_recods_count, @limit, @page
@offset ||= @evaluate_recods_pages.offset
@evaluate_recods = paginateHelper @evaluate_recods, @limit
respond_to do |format|
format.js
format.html
end
end
# 作业回复
def leave_message
@menu_type = 8
@sub_type = 1
@jour = JournalsForMessage.where(:jour_type => 'HomeworkCommon').order("created_on desc")
@jour_count = @jour.count
@page = (params['page'] || 1).to_i
@limit = 20
@is_remote = true
@jour_pages = Paginator.new @jour_count, @limit, params['page'] || 1
@offset ||= @jour_pages.offset
@jour = paginateHelper @jour, @limit
respond_to do |format|
format.html
format.js
end
end
# 讨论区
def messages_list
@menu_type = 8
@sub_type = 3
@memo = Memo.where("0=0").order("created_at desc")
@page = (params['page'] || 1).to_i
@memo_count = @memo.count
@limit = 20
@is_remote = true
@memo_pages = Paginator.new @memo_count, @limit, params['page'] || 1
@offset ||= @memo_pages.offset
@memo = paginateHelper @memo, @limit
respond_to do |format|
format.html
format.js
end
end
def course_messages_list
@menu_type = 8
@sub_type = 4
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
# @message = Message.find_by_sql("SELECT * FROM messages WHERE board_id IN (SELECT id FROM boards WHERE course_id IS NOT NULL) order by created_on #{@sx_order}")
@message = Message.includes(:board).where("boards.course_id is not null").order("created_on #{@sx_order}")
@page = (params['page'] || 1).to_i
@message_count = @message.count
@limit = 20
@is_remote = true
@message_pages = Paginator.new @message_count, @limit, params['page'] || 1
@offset ||= @message_pages.offset
@message = paginateHelper @message, @limit
respond_to do |format|
format.js
format.html
end
end
# 专业列表
def profession
@major=Major.where("0=0")
# @menu_type = 12
@sub_type = 1
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
major_level_option = params[:major_level] if params[:major_level]
discipline_category_option = params[:discipline_category_id] if params[:discipline_category_id]
first_level_discipline_option = params[:first_level_discipline_id] if params[:first_level_discipline_id]
if major_level_option && major_level_option != '0'
@major = @major.where(:major_level => major_level_option)
end
if discipline_category_option && discipline_category_option != '0'
@major=@major.where(:discipline_category_id => discipline_category_option)
end
if first_level_discipline_option && first_level_discipline_option != '0'
@major=@major.where(:first_level_discipline_id => first_level_discipline_option)
end
if params[:support_shixuns]
@major = @major.where(:support_shixuns => params[:support_shixuns].to_i,:major_level=> 2)
end
@major = @major.order("created_at #{@sx_order}")
@major_count = @major.count
limit = 20
@is_remote = true
@major_pages = Paginator.new @major_count, limit, params['page'] || 1
@offset ||= @major_pages.offset
@major = paginateHelper @major, limit
respond_to do |format|
format.js
format.html
end
end
# 新增专业页面
def new_major
respond_to do |format|
format.js
end
end
# 新增专业
def insert_major
major_list = Major.create(:name=>params[:major],:first_level_discipline_id=>params[:first_level_discipline_id],:major_level=>params[:major_level],:discipline_category_id=>params[:discipline_category_id],:major_code=>params[:major_code])
redirect_to profession_managements_path
end
# 支撑实训
def support_shixun
if params[:syllabus_id]
major = Major.find params[:syllabus_id]
major.update_attributes(:support_shixuns => !major.support_shixuns)
end
end
# 实训适用课程
def applicable_course
# @menu_type = 12
@sub_type = 2
@major = Major.where(:major_level => 2,:support_shixuns => 1)
@courselist = CourseList.where("0=0")
search=params[:search]
unless search.blank?
@courselist = @courselist.where("name like '%#{search}%'")
end
@courselist = @courselist.reorder("created_at desc")
@courselist_count = @courselist.count
@limit = 15
@is_remote = true
@page = params['page'] ? params['page'].to_i : 1
@courselist_pages = Paginator.new @courselist_count, @limit, @page
@offset ||=@courselist_pages.offset
@courselist = paginateHelper @courselist, @limit
respond_to do |format|
format.js
format.html
end
end
# 增加课程
def add_course
courselist= CourseList.create(:name => params[:course])
redirect_to applicable_course_managements_path
end
# 增加课程所属专业
def add_major
data = {result: 0}
id = MajorCourse.where(:course_list_id => params[:course_list_id]).first
if (id.nil?) || (params[:major_id].to_i != '0' && params[:major_id].to_i != id.major_id)
MajorCourse.create(:course_list_id => params[:course_list_id],:major_id=>params[:major_id])
data[:result] = 1
end
render :json => data
end
# 竞赛列表
def competition
@menu_type = 5
@sub_type = 1
@competitions = Competition.order("created_at desc")
respond_to do |format|
format.js
format.html
end
end
# 竞赛报名列表
def enroll_list
@order = params[:order].blank? ? "desc" : params[:order]
@competition = Competition.where(:id => params[:competition]).first
@team_members = @competition.team_members.includes(:user => [:user_extensions => [:school]])
if params[:school] || params[:location]
school_ids = School.where("schools.name like '%#{params[:school]}%'").pluck(:id)
school_ids = school_ids.size == 0 ? "(-1)" : "(" + school_ids.join(",") + ")"
location = params[:location] && params[:location] != "0" ? params[:location] : ""
@team_members = @team_members.where("user_extensions.school_id in #{school_ids} and schools.province like '%#{location}%'")
end
@page = params[:page] || 1
@team_members = @team_members.reorder("team_members.created_at #{@order}")
all_members = @team_members
@team_members = paginateHelper @team_members, 50
respond_to do |format|
format.js
format.html
format.xls{
filename = "#{Time.now.strftime("%Y%m%d")}-#{@competition.name}.xls"
send_data(competition_member_xls(all_members, @competition), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
def competition_setting
@menu_type = 5
@sub_type = 1
if Competition.where(:identifier => params[:com_id]).blank?
@competition = Competition.where(:id => params[:com_id]).first
else
@competition = Competition.where(:identifier => params[:com_id]).first
end
end
def create_competition_text
CompetitionTextConfig.create(:name => params[:name], :description => params[:description], :competition_id => params[:competition_id])
render :json => {:status => 1}
end
def delete_competition_text
ctc = CompetitionTextConfig.find params[:id]
ctc.destroy
render :json => {:status => 1}
end
# 导入单位部门
def import_departments
attachments = params[:attachments]
attachments.each do |attachment|
attachment = Attachment.find_by_token_only(attachment[1]['token'])
if attachment.present?
attachment.container_id = 1
attachment.container_type = "ImportDepartment"
attachment.save
end
end
new_atta = Attachment.where(:container_id => 1, :container_type => "ImportDepartment").last
if new_atta.present?
Rails.logger.info("---------------------attachment_id #{new_atta.id}")
path = new_atta.disk_directory
name = new_atta.disk_filename
if name.split(".").last == "xls"
begin
xls = Roo::Spreadsheet.open("files/#{path}/#{name}",extension: :xls)
worksheet = xls.sheet(0)
n2 = worksheet.last_row #最后一行数
rows = n2 - 1
count = 0
rows.times do |r| #行数
school_id = worksheet.cell(r+2, 1)
if school_id.present?
school = School.where(:id => school_id).first
if school.present?
if school.departments.where(:name => worksheet.cell(r+2, 2)).count == 0
school.departments << Department.new(:name => worksheet.cell(r+2, 2), :is_auth => 1)
count = count + 1
end
end
end
end
@status = "已导入#{count}个部门"
rescue
@status = "无法完成导入,原因:文件内容无法读取"
end
else
@status = "无法完成导入,原因:文件类型错误(只支持.xls文件)"
end
new_atta.destroy
else
@status = "无法完成导入,原因:文件不存在"
end
respond_to do |format|
format.js
end
end
# 单位部门列表
def departments
@menu_type = 6
@sub_type = 2
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
@department = Department.where(:is_auth => 1).is_active
search = params[:search]
admin = params[:admin].to_i
url = params[:url].to_i
if search.blank?
@department = @department
else
apply = School.where("name like '%#{search}%'").map(&:id)
@department = @department.where(:school_id => apply)
end
if admin == 0
@department = @department
else
department_ids = DepartmentMember.pluck(:department_id).uniq
@department = @department.where(:id => department_ids)
end
if url == 1
@department = @department.where("identifier is not null and identifier != ''")
end
@department = @department.reorder("created_at #{@sx_order}")
@page = (params['page'] || 1).to_i
@department_count =@department.count
@limit = 20
@is_remote = true
@department_pages = Paginator.new @department_count, @limit, params['page'] || 1
@offset ||=@department_pages.offset
@department = paginateHelper @department, @limit
respond_to do |format|
format.js
format.html
end
end
# 删除部门管理员
def delete_depart_member
DepartmentMember.where(:department_id => params[:depart], :user_id => params[:user_id]).destroy_all
end
# 添加部门管理员-弹框
def add_depart_member_box
@department = Department.where(:id => params[:depart]).first
#@members = User.where(:id => UserExtensions.where(:school_id => @department.try(:school_id)).map(&:user_id), :certification => 1)
@members =
if params[:search]
User.where("LOWER(concat(lastname, firstname, nickname, mail)) LIKE '%#{params[:search]}%'")
else
User.where(:certification => 1)
end
@members = paginateHelper @members, 8
end
# 添加部门管理员
def add_depart_member
if params[:depart] && params[:depart_member]
@department = Department.where(:id => params[:depart]).first
params[:depart_member].each do |member|
@department.department_members << DepartmentMember.new(:user_id => member)
end
end
end
# check 部门 identifier是否重复
def check_depart_identifier
logger.info("###############{params}")
if params[:depart]
result = Department.where("id != #{params[:depart]} and identifier = '#{params[:identifier]}'").count == 0 || params[:identifier] == ""
render :json => {result: result}
end
end
# 更新部门 identifier
def update_depart_identifier
if params[:depart] && params[:identifier]
@department = Department.where(:id => params[:depart]).first
@department.update_attributes(:identifier => params[:identifier]) if @department.present?
end
end
# 更新部门 host_count
def update_host_count
if params[:depart] && params[:host_count]
@department = Department.where(:id => params[:depart]).first
@department.update_attributes(:host_count => params[:host_count]) if @department.present?
end
end
# 新增
def create_departments
dep = Department.order("created_at desc").first
@latest_school = School.find(dep.try(:school_id)).try(:name)
@school_id = dep.try(:school_id)
respond_to do |format|
format.js
end
end
def add_department
department = Department.where(:school_id => params[:school], :name => params[:department]).first
if department.nil?
department = Department.create(:school_id => params[:school],:name => params[:department],:is_auth => 1)
ApplyAddDepartment.create(:school_id => params[:school],
:status => 1,
:name => params[:department],
:department_id => department.id,
:user_id => User.current.id)
end
redirect_to departments_managements_path
end
# 修改单位部门列表
def update_department
dep = Department.find params[:department_id]
@edit_id = params[:department_id]
@search = params[:search]
if !params[:search].nil?
search = "%#{params[:search].to_s.strip.downcase}%"
@departments = Department.where("school_id = #{dep.school_id} and is_auth = 1 and id != #{params[:department_id].to_i} and #{Department.table_name}.name like :p", :p => search)
#@schools = School.all
else
@departments = Department.where("school_id = #{dep.school_id} and is_auth = 1 and id != #{params[:department_id].to_i}")
end
respond_to do |format|
format.js
end
end
def edit_departments_school
begin
dep = Department.find(params[:department_id])
alter_dep = Department.find(params[:alter_dep_id])
apply_dep = ApplyAddDepartment.where(:department_id => params[:alter_dep_id])
if dep && alter_dep && dep != alter_dep
# users = UserExtensions.where("department_id = #{dep.id}")
# users.update_all(:department_id => params[:alter_dep_id])
# dep.destroy
# apply_dep.update_all(:status => 2)
# ApplyAddDepartment.where(:department_id =>params[:departments]).update_all(:department_id=>department_id)
# users = UserExtensions.where("department_id = #{alt_dep.department_id}")
# users.update_all(:department_id => department.id)
apply_dep.destroy_all;
users = UserExtensions.where(:department_id => params[:alter_dep_id])
users.update_all(:department_id => dep.id)
alter_dep.destroy
end
rescue Exception => e
puts e
end
redirect_to departments_managements_path
end
# 单位列表
def departments_part
@menu_type = 6
@sub_type = 1
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
search = params[:search]
if search.blank?
@schools = School.where("0=0")
else
@schools = School.where("name like '%#{search}%'")
end
if params[:index] == '8'
@schools = @schools.reorder("created_at #{@sx_order}")
@order_type = "created_at"
elsif params[:index] == '9'
@schools = @schools.reorder("updated_at #{@sx_order}")
@order_type = "updated_at"
elsif params[:index] == "6"
@order_type = "usercount"
@schools.each do |school|
school[:usercount] = UserExtensions.where(:school_id => school.id).count
end
@sx_order == "desc" ? @schools = @schools.sort{|x,y| y[:usercount] <=> x[:usercount]} : @schools = @schools.sort{|x,y| x[:usercount] <=> y[:usercount]}
else
@schools = @schools.reorder("created_at #{@sx_order}")
end
@page = (params['page'] || 1).to_i
@schools_count = @schools.count
@limit = 20
@is_remote = true
@schools_pages = Paginator.new @schools_count, @limit, params['page'] || 1
@offset ||= @schools_pages.offset
@schools= paginateHelper @schools, @limit
respond_to do |format|
format.js
format.html
end
end
# 新增部门名称
def add_departments_part
end
# 修改单位名称
def upload_logo
@menu_type = 6
@sub_type = 1
@next_type = 1
@school = School.find(params[:school])
end
# 添加学校视频描述
def add_contents_for_school
school = School.find params[:school_id]
school.update_attributes(:video_desc => params[:video_desc], :video_name => params[:video_name])
render :json => {status: 1, message: "创建成功!"}
end
# 添加学校课程信息
def add_course_info_for_school
school = School.find params[:school_id]
school.update_attributes(:course_link => params[:course_link], :course_name => params[:course_name])
render :json => {status: 1, message: "创建成功!"}
end
# 修改单位名称为其他
def school_upload_logo
school = School.where(:id => params[:applied_id]).first
ApplyAddSchools.where(:school_id => params[:applied_id]).destroy_all
before_apply_departments = Department.where(:school_id => params[:applied_id])
before_apply_departments.each do |department|
after_dep = Department.where(:school_id => params[:school_id], :name => department.name).first
if after_dep
UserExtensions.where(:school_id => params[:applied_id], :department_id => department.id).update_all(:department_id => after_dep.id)
department.destroy
else
department.apply_add_departments.update_all(:school_id => params[:school_id])
department.update_attribute(:school_id, params[:school_id])
end
end
UserExtensions.where(:school_id => params[:applied_id]).update_all(:school_id => params[:school_id])
school.destroy
redirect_to departments_part_managements_path
end
# 修改单位信息
def school_message_update
school_name = params[:schoolname]
school_id = params[:school_id]
School.where(:id => school_id).update_all(:name => school_name,:province => params[:province],:city =>params[:city],:address => params[:address],:shool_code => params[:school_code], :identifier => params[:identifier])
redirect_to departments_part_managements_path
end
# 删除单位
def delete_school
school = School.where(:id => params[:school]).first
UserExtensions.where(:school_id => params[:school]).update_all(:school_id => nil, :department_id => nil)
ApplyAddSchools.where(:school_id => params[:school]).destroy_all
ApplyAddDepartment.where(:school_id => params[:school]).destroy_all
school.destroy
redirect_to departments_part_managements_path
end
def save_school
uploaded_io = params[:logo]
school_pinyin = Pinyin.t(params[:schoolname].strip, splitter: '')
sl = School.create(:name => params[:schoolname],:province => params[:province],:city => params[:city],:address => params[:address],:pinyin =>school_pinyin)
# unless uploaded_io.nil?
# File.open(Rails.root.join('public', 'images', 'school', sl.id.to_s+'.png'), 'wb') do |file|
# file.write(uploaded_io.read)
# end
# sl.logo_link = '/images/school/'+sl.id.to_s+'.png'
# sl.save
# end
@user = User.current
@se = @user.extensions
# if @user.save && @se.save
# diskfile1 = disk_filename('school', sl.id , 'id')
# diskfileID = diskfile1 + 'temp'
# begin
# FileUtils.mv diskfileID, diskfile1, force: true if File.exist? diskfileID
# ensure
# File.delete(diskfileID) if File.exist?(diskfileID)
# end
# end
redirect_to departments_part_managements_path
end
# 部门审核
def depart
@menu_type = 10
@sub_type = 3
search = params[:search]
@apply_status = ApplyAddDepartment.where(:status=>0)
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
if search.blank?
@apply_status = @apply_status.where("0=0")
else
@apply_status= @apply_status.where("name like '%#{search}%'")
end
@apply_status = @apply_status.order("created_at #{@sx_order}")
@apply_status_count = @apply_status.count
limit = 20
@is_remote = true
@apply_status_pages = Paginator.new @apply_status_count, limit, params['page'] || 1
@offset ||=@apply_status_pages.offset
@apply_status = paginateHelper @apply_status, limit
respond_to do |format|
format.js
format.html
end
end
# 批准
def approve_applied_departments
applied_department = ApplyAddDepartment.find(params[:id])
applied_message = AppliedMessage.where(:applied_id => applied_department.id, :applied_type => "ApplyAddDepartment")
applied_message.update_all(:status => 1)
if applied_department.department
applied_department.department.update_attributes(:is_auth => 1)
end
applied_department.update_attribute(:status, 1) unless applied_department.nil?
# AppliedMessage.create(:user_id => applied_department.user_id, :status => 1, :viewed => 0, :applied_id => applied_department.id, :applied_type => "ApplyAddDepartment", :name => applied_department.name )
UserExtensions.where(:user_id => applied_department.user_id).update_all(:department_id => applied_department.department_id)
Tiding.where(:user_id => 1, :trigger_user_id => applied_department.user_id, :container_id => applied_department.id, :container_type => 'ApplyAddDepartment', :status => 0, :tiding_type => "Apply").update_all(:status => 1)
Tiding.create(:user_id => applied_department.user_id, :trigger_user_id => 0, :container_id => applied_department.id, :container_type =>'ApplyAddDepartment', :belong_container_id => applied_department.department.school_id, :belong_container_type=> 'School', :tiding_type => "System", :status => 1)
respond_to do |format|
format.html{ redirect_to depart_managements_path }
end
end
# 删除
def delete_applied_departments
applied_department = ApplyAddDepartment.find params[:depart_id]
applied_message = AppliedMessage.where(:applied_id => applied_department.id, :applied_type => "ApplyAddDepartment")
applied_message.update_all(:status => 3)
applied_department.update_attribute(:status, 3)
# 未审批删除
if params[:tip] == "unapplied"
# AppliedMessage.create(:user_id => applied_department.user_id, :status => 3, :viewed => 0, :applied_id => applied_department.id, :applied_type => "ApplyAddDepartment", :name => applied_department.name )
Tiding.where(:user_id => 1, :trigger_user_id => applied_department.user_id, :container_id => applied_department.id, :container_type => 'ApplyAddDepartment', :status => 0, :tiding_type => "Apply").update_all(:status => 1)
Tiding.create(:user_id => applied_department.user_id, :trigger_user_id => 0, :container_id => applied_department.id, :container_type =>'ApplyAddDepartment', :belong_container_id => applied_department.department.school_id, :belong_container_type=> 'School', :tiding_type => "System", :status => 2, :extra => params[:reason])
# 删除学校的用户
users = UserExtensions.where("department_id = #{applied_department.department_id}")
users.update_all(:department_id => nil)
applied_department.department.destroy
# 已审批删除
elsif params[:tip] == "applied"
applied_department.destroy
end
respond_to do |format|
format.html{ redirect_to depart_managements_path }
end
end
# 部门修改
def all_department
@edit_id = params[:department_id]
@search = params[:search]
dep = ApplyAddDepartment.where(:id => @edit_id).first
if !params[:search].nil?
search = "%#{params[:search].to_s.strip.downcase}%"
@department = dep.school.departments.where("is_auth = 1 and #{Department.table_name}.name like :p", :p => search)
else
@department = dep.school.departments.where(:is_auth => 1)
end
respond_to do |format|
format.js
end
# redirect_to unit_managements_path
end
# 修改
def edit_applied_department
aas =ApplyAddDepartment.find(params[:applied_id])
# aas.update_attribute(:name, params[:name])
#applied_add_school = ApplyAddSchools.where(:name => aas.name)
department =Department.find params[:department_id]
begin
#更新消息表的status
if aas.department_id != department.id.to_i
apply_depart_id = aas.department_id
applied_message = AppliedMessage.where(:applied_id => apply_depart_id, :applied_type => "ApplyAddDepartment")
applied_message.update_all(:status => 4)
aas.update_attribute(:status, 2)
aas.tidings.update_all(:status => 1)
extra = department.name + "(#{department.school.try(:name)})"
Tiding.create(:user_id => aas.user_id, :trigger_user_id => 0, :container_id => aas.id, :container_type =>'ApplyAddDepartment', :belong_container_id => department.school_id, :belong_container_type=> 'School', :tiding_type => "System", :status => 3, :extra => extra)
# AppliedMessage.create(:user_id => aas.user_id, :status => 2, :viewed => 0, :applied_id => aas.id, :applied_type => "ApplyAddDepartment", :name =>department.name )
users = UserExtensions.where("department_id = #{aas.department_id}")
users.update_all(:department_id => department.id)
aas.department.destroy
ApplyAddDepartment.where(:department_id => aas.department_id).update_all(:department_id => department.id)
Department.where(:department_id => aas.department_id).destroy_all
aas.destroy_all
end
rescue Exception => e
puts e
end
redirect_to depart_managements_path
end
# 单位审批
def unit
@menu_type = 10
@sub_type = 4
search = params[:search]
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
@apply_status = ApplyAddSchools.where(:status=>0)
if search.blank?
@apply_status = @apply_status.where("0=0")
else
@apply_status= @apply_status.where("name like '%#{search}%'")
end
@apply_status = @apply_status.order("created_at #{@sx_order}")
@apply_status_count = @apply_status.count
limit = 20
@is_remote = true
@apply_status_pages = Paginator.new @apply_status_count, limit, params['page'] || 1
@offset ||= @apply_status_pages.offset
@apply_status = paginateHelper @apply_status, limit
respond_to do |format|
format.js
format.html
end
end
# 单位审批批准
def approve_applied_schools
applied_school = ApplyAddSchools.where(:id =>params[:id]).first
applied_message_id = applied_school.school_id
applied_message = AppliedMessage.where(:applied_id => applied_message_id, :applied_type => "ApplyAddSchools")
applied_message.update_all(:status => 1)
unless applied_school.nil?
applied_school.update_column('status', 1)
end
school = applied_school.school
school.update_attribute("province", applied_school.province)
AppliedMessage.create(:user_id => applied_school.user_id, :status => 1, :viewed => 0, :applied_id => applied_school.id, :applied_type => "ApplyAddSchools", :name => applied_school.name )
Tiding.where(:user_id => 1, :trigger_user_id => applied_school.user_id, :container_id => applied_school.id, :container_type => 'ApplyAddSchools', :status => 0, :tiding_type => "Apply").update_all(:status => 1)
Tiding.create(:user_id => applied_school.user_id, :trigger_user_id => 0, :container_id => applied_school.id, :container_type =>'ApplyAddSchools', :belong_container_id => applied_school.school_id, :belong_container_type=> 'School', :tiding_type => "System", :status => 1)
redirect_to unit_managements_path
end
# 删除
def delete_applied_schools
applied_school = ApplyAddSchools.find(params[:school_id])
applied_message_id = applied_school.school_id
applied_message = AppliedMessage.where(:applied_id => applied_message_id, :applied_type => "ApplyAddSchools")
applied_message.update_all(:status => 3)
applied_school.update_attribute(:status, 3)
# 单位对应的部门审核也应做删除处理
applied_departments = ApplyAddDepartment.where(:school_id => applied_school.school_id)
applied_departments.update_all(:status => 3)
AppliedMessage.where(:applied_id => applied_departments.map(&:id), :applied_type => "ApplyAddDepartment").update_all(:status => 3)
# 删除学校的用户
users = UserExtensions.where("school_id = #{applied_school.school_id}")
# 申请了职业认证的用户撤销申请
apply_user_auth = ApplyUserAuthentication.where(:user_id => users.map(&:user_id), :auth_type => 2, :status => 0)
apply_user_auth.each do |apply|
apply.tidings.destroy_all
apply.update_attribute('status', 3)
diskfile2 = disk_auth_filename('UserAuthentication', apply.user_id, 'PRO')
diskfilePRO = diskfile2 + 'temp'
File.delete(diskfilePRO) if File.exist?(diskfilePRO)
File.delete(diskfile2) if File.exist?(diskfile2)
end
users.update_all(:school_id => nil, :department_id => nil)
# 未审批删除
if params[:tip] == "unapplied"
# AppliedMessage.create(:user_id => applied_school.user_id, :status => 3, :viewed => 0, :applied_id => applied_school.id, :applied_type => "ApplyAddSchools", :name => applied_school.name )
Tiding.where(:user_id => 1, :trigger_user_id => applied_school.user_id, :container_id => applied_school.id, :container_type => 'ApplyAddSchools', :status => 0, :tiding_type => "Apply").update_all(:status => 1)
Tiding.create(:user_id => applied_school.user_id, :trigger_user_id => 0, :container_id => applied_school.id, :container_type =>'ApplyAddSchools', :belong_container_id => applied_school.school_id, :belong_container_type=> 'School', :tiding_type => "System", :status => 2, :extra => params[:reason])
Tiding.where(:user_id => 1, :container_id => applied_departments.map(&:id), :container_type => 'ApplyAddDepartment', :status => 0, :tiding_type => "Apply").update_all(:status => 1)
if applied_departments.first
Tiding.create(:user_id => applied_departments.first.user_id, :trigger_user_id => 0, :container_id => applied_departments.first.id, :container_type =>'ApplyAddDepartment', :belong_container_id => applied_school.school_id, :belong_container_type=> 'School', :tiding_type => "System", :status => 2)
AppliedMessage.create(:user_id => applied_departments.first.user_id, :status => 3, :viewed => 0, :applied_id => applied_departments.first.id, :applied_type => "ApplyAddDepartment", :name => applied_departments.first.name )
end
applied_school.school.destroy
applied_school.school.departments.destroy_all
redirect_to unit_managements_path
# 已审批删除
elsif params[:tip] == "applied"
applied_departments.destroy_all
applied_school.destroy
redirect_to unit_managements_path
end
end
# 单位审批修改
def all_schools
apply_schools = ApplyAddSchools.where("status = 0")
apply_school_ids = apply_schools.empty? ? "(#{params[:school_id].to_i})" : "(" + apply_schools.map{|sc| sc.school_id}.join(',') + ")"
if !params[:search].nil?
search = "%#{params[:search].to_s.strip.downcase}%"
@schools = School.where("id not in #{apply_school_ids} and id != #{params[:school_id].to_i} and #{School.table_name}.name like :p", :p => search)
else
@schools = School.where("id not in #{apply_school_ids} and id != #{params[:school_id].to_i}")
end
@edit_id = params[:school_id]
@search = params[:search]
@upload = params[:upload]
respond_to do |format|
format.js
end
end
# 修改
def edit_applied_schools
aas = ApplyAddSchools.find(params[:applied_id])
school = School.find params[:school_id]
begin
#更新消息表的status
if aas.school_id != school.id.to_i
applied_message_id = aas.school_id
applied_message = AppliedMessage.where(:applied_id => applied_message_id, :applied_type => "ApplyAddSchools")
applied_message.update_all(:status => 4)
Tiding.where(:user_id => 1, :trigger_user_id => aas.user_id, :container_id => aas.id, :container_type => 'ApplyAddSchools', :status => 0, :tiding_type => "Apply").update_all(:status => 1)
aas.update_attribute(:status, 2)
# AppliedMessage.create(:user_id => aas.user_id, :status => 2, :viewed => 0, :applied_id => aas.id, :applied_type => "ApplyAddSchools", :name => school.name )
extra = school.try(:name).to_s
Tiding.create(:user_id => aas.user_id, :trigger_user_id => 0, :container_id => aas.id, :container_type =>'ApplyAddSchools', :belong_container_id => school.id, :belong_container_type=> 'School', :tiding_type => "System", :status => 3, :extra => extra)
users = UserExtensions.where("school_id = #{aas.school_id}")
users.update_all(:school_id => school.id)
ApplyAddDepartment.where(:school_id => aas.school_id).update_all(:school_id => school.id)
# 判断重复
before_apply_departments = Department.where(:school_id => aas.school_id)
before_apply_departments.each do |department|
after_dep = Department.where(:school_id => params[:school_id], :name => department.name).first
if after_dep.present?
UserExtensions.where(:school_id => aas.school_id, :department_id => department.id).update_all(:department_id => after_dep.id)
department.destroy
department.apply_add_departments.destroy_all
else
department.apply_add_departments.update_all(:school_id => school.id)
department.update_attribute(:school_id, school.id)
end
end
UserExtensions.where(:school_id => aas.school_id).update_all(:school_id => params[:school_id])
# Department.where(:school_id => aas.school_id).update_all(:school_id => school.id)
aas.school.destroy
aas.update_attribute(:school_id, school.id)
end
rescue Exception => e
puts e
end
redirect_to unit_managements_path
end
# 课程列表
def classroom
@menu_type = 2
@sub_type = 1
@courselist = CourseList.where("0=0")
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
keyword = params[:keyword]
search = params[:search]
if params[:support_shixuns_search_title]
@courselist = @courselist.where(:support_shixuns_search => params[:support_shixuns_search_title].to_i)
end
if search.blank?
@courselist = @courselist
else
if "u_name" == keyword
# user_id = User.where("concat(lastname, firstname) like '%#{search}%'")
@courselist = @courselist.includes(:user).where("concat(users.lastname, users.firstname) like '%#{search}%'")
else
@courselist = @courselist.where("name like '%#{search}%'")
end
end
@courselist = @courselist.order("course_lists.id #{@sx_order}")
@page = (params[:page] || 1).to_i
@courselist_count = @courselist.count
@limit = 20
@courselist_pages = Paginator.new @courselist_count, @limit, @page
@offset ||= @courselist_pages.offset
@courselist = paginateHelper @courselist,@limit
# @courselist = @courselist.order("courselist.created_at #{@sx_order}")
respond_to do |format|
format.js
format.html
end
end
def rename_class
@page = params[:page]
@courselist = CourseList.where(:id => params[:course_list]).first
if request.get?
respond_to do |format|
format.js
end
else
if @courselist
o_courselist = CourseList.where(:name => params[:name]).first
if o_courselist
@courselist.courses.each do |course|
course.update_attributes(:name => course.name.sub(@courselist.name, params[:name]), :course_list_id => o_courselist.id)
end
@courselist.shixun_major_courses.update_all(:course_list_id => o_courselist.id, :major_id => @courselist.major_courses.first.try(:major_id))
@courselist.destroy
else
@courselist.courses.each do |course|
course.update_attribute(:name, course.name.sub(@courselist.name, params[:name]))
end
@courselist.update_attributes(:name => params[:name])
end
end
redirect_to classroom_managements_path(:page => params[:page])
end
end
def migrate_class
@page = params[:page]
@courselist = CourseList.where(:id => params[:course_list]).first
if request.get?
respond_to do |format|
format.js
end
else
if @courselist
o_courselist = CourseList.where(:name => params[:name]).first
if o_courselist
@courselist.courses.each do |course|
course.update_column(:course_list_id, o_courselist.id)
end
@courselist.shixun_major_courses.update_all(:course_list_id => o_courselist.id, :major_id => @courselist.major_courses.first.try(:major_id))
@courselist.destroy
else
@courselist.update_column(:name, params[:name])
end
end
redirect_to classroom_managements_path(:page => params[:page])
end
end
# 支撑实训检索
def support_shixuns_search
if params[:shixun_id]
courselist = CourseList.find params[:shixun_id]
courselist.update_attributes(:support_shixuns_search => !courselist.support_shixuns_search)
end
end
# 课堂列表
def classroom_classment
@menu_type = 2
@sub_type = 2
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
@courses = Course.where(:is_delete => 0)
@timing=Course.where(:is_end=>false).count
@end=Course.where(:is_end=>true).count
# unless params[:school_id] || params[:search] || params[:keyword] || params[:status]
# user_exs = UserExtensions.where(:school_id=> @courses.map(&:school_id))
# @schools = School.where(:id =>user_exs.map(&:school_id))
# end
@search = params[:search] # 搜索字
@keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/课程名搜索
@status = params[:status]
@school_id = params[:school_id]
if params[:school_id] && params[:school_id] != ''
@courses = Course.joins("join users u on courses.tea_id = u.id").joins("join user_extensions ue on u.id = ue.user_id").where("ue.school_id = #{params[:school_id]}")
end
if params[:homepage_show]
@courses = @courses.where(:homepage_show => params[:homepage_show].to_i)
end
if params[:course_list] && params[:course_list] != ''
course_name = "%#{params[:course_list].strip}%"
course_lists = CourseList.where("name like '#{course_name}'").map(&:id)
@courses = @courses.where(:course_list_id => course_lists)
end
if params[:status] && params[:status]!=''
@courses = @courses.where(:is_end => @status.to_i)
end
if "u_name" == @keyword
if @search.blank?
@courses = @courses
else
user_id = User.where("concat(lastname, firstname) like '%#{@search}%'")
@courses = @courses.joins("join users u on courses.tea_id = u.id").where("concat(u.lastname, u.firstname) like '%#{@search}%'")
end
else
school = School.where("name like '%#{@search}%'").map(&:id)
@courses = @courses.where(:school_id => school)
# @courses= @courses.where("name like '%#{@search}%'")
end
@courses = @courses.select("courses.*,(SELECT MAX(updated_at) FROM `course_activities` WHERE course_activities.course_id = courses.id) AS updatetime").order("updatetime desc")
@page = (params['page'] || 1).to_i
@export_courses = @courses
@courses_count = @courses.count
@limit = 20
@is_remote = true
@courses_pages = Paginator.new @courses_count, @limit, params['page'] || 1
@offset ||= @courses_pages.offset
@courses = paginateHelper @courses, @limit
respond_to do |format|
format.js
format.html
format.xls{
@export_courses = @export_courses.all
filename = "#{l(:label_course_list_xls)}.xls"
send_data(course_list_xls(@export_courses), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
def hidden_course
@course = Course.where(:id => params[:course_id]).first
@course.update_attributes(:is_hidden => !@course.is_hidden) if @course.present?
end
def shixun_task
@menu_type = 2
@sub_type = 3
homework_commons = HomeworkCommon.where(:homework_type => 4)
@shixun_task = Course.where(:id => homework_commons.map(&:course_id))
@keyword = params[:keyword]
@search = params[:search]
@school_id = params[:school_id]
if params[:school_id] && params[:school_id] != ''
@shixun_task = @shixun_task.joins("join users u on courses.tea_id = u.id").joins("join user_extensions ue on u.id = ue.user_id").where("ue.school_id = #{params[:school_id]}")
# @shixun_task = @shixun_task.includes(:user => {:user_extensions => []}).where("user_extensions.school_id = #{params[:school_id]}")
end
unless @search.blank?
if "u_name" == @keyword
user_id = User.where("concat(lastname, firstname) like '%#{@search}%'")
@shixun_task = @shixun_task.joins("join users u on courses.tea_id = u.id").where("concat(u.lastname, u.firstname) like '%#{@search}%'")
else
@shixun_task = @shixun_task.where("courses.name like '%#{@search}%'")
end
end
# @shixun_task = @shixun_task.select("courses.*, (select h.publish_time from homework_commons h where h.course_id = courses.id group by courses.id) AS publish_time").reorder("publish_time desc")
@page = (params['page'] || 1).to_i
@shixun_task_count = @shixun_task.size
@export_shixun_task = @shixun_task
@limit = 20
@is_remote = true
@shixun_task_pages = Paginator.new @shixun_task_count, @limit, params['page'] || 1
@offset ||= @shixun_task_pages.offset
@shixun_task = paginateHelper @shixun_task, @limit
@shixun_task = @shixun_task.includes(:homework_commons => {:student_works => [], :homework_detail_manual => [], :shixuns => []}, :teacher => {:user_extensions => []})
respond_to do |format|
format.js
format.html
format.xls{
# @export_shixun_task = @export_shixun_task.all
filename = "#{l(:label_shixun_task_xls)}.xls"
send_data(shixun_task_xls(@export_shixun_task), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
def project_list
@menu_type = 2
@sub_type = 4
@pr_order = params[:pr_order].blank? ? "desc" : params[:pr_order]
@search = params[:search].to_s
@projects = Project.where("name like '%#{@search}%'").order("created_on #{@pr_order}")
@limit = 20
@page = (params['page'] || 1).to_i
@projects = paginateHelper @projects, @limit
respond_to do |format|
format.js
format.html
end
end
# 班级首页显示
def course_homepage_show
if params[:course_id]
course = Course.find params[:course_id]
course.update_attributes(:homepage_show => !course.homepage_show)
end
end
# 课程实训
def class_shixuns
@menu_type = 4
@sub_type = 1
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
@edit_class_sx_num=Subject.where(:status => 0).count
@audit_class_sx_num=Subject.where(:status => 1).count
@publish_class_sx_num=Subject.where(:status => 2).count
@repertories = Repertoire.where(nil).order("CONVERT( name USING gbk ) COLLATE gbk_chinese_ci ASC")
search = params[:search] # 搜索字
keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/课程名搜索
status = params[:status].to_i
if params[:school_id] && params[:school_id] != '0'
@c_shixuns = Subject.includes(:user => {:user_extensions => []}).where("user_extensions.school_id = #{params[:school_id]}")
else
@c_shixuns = Subject.where("0=0")
end
if params[:status] && params[:status]!=''
@c_shixuns= @c_shixuns.where(:status =>status)
end
if search.blank?
@c_shixuns = @c_shixuns
else
if "u_name" == keyword
# user_id = User.where("concat(lastname, firstname) like '%#{search}%'")
@c_shixuns = @c_shixuns.includes(:user).where("concat(users.lastname, users.firstname) like '%#{search}%'")
else
@c_shixuns= @c_shixuns.where("name like '%#{search}%'")
end
end
unless params[:school_id] || params[:search] || params[:keyword] || params[:status]
user_exs = UserExtensions.where(:user_id => @c_shixuns.map(&:user_id))
@schools = School.where(:id => user_exs.map(&:school_id))
end
@c_shixuns = @c_shixuns.order("subjects.created_at #{@sx_order}")
@page = (params['page'] || 1).to_i
@c_shixuns_count = @c_shixuns.count
@limit = 20
@c_shixuns_pages = Paginator.new @c_shixuns_count, @limit, @page
@c_shixuns = paginateHelper @c_shixuns, @limit
@offset ||= @c_shixuns_pages.offset
respond_to do |format|
format.js
format.html
end
end
def subject_setting_list
@menu_type = 4
@sub_type = 2
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
@edit_class_sx_num=Subject.where(:status => 0).count
@audit_class_sx_num=Subject.where(:status => 1).count
@publish_class_sx_num=Subject.where(:status => 2).count
@repertories = Repertoire.where(nil).order("CONVERT( name USING gbk ) COLLATE gbk_chinese_ci ASC")
search = params[:search] # 搜索字
keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/课程名搜索
status = params[:status].to_i
if params[:school_id] && params[:school_id] != '0'
@c_shixuns = Subject.includes(:user => {:user_extensions => []}).where("user_extensions.school_id = #{params[:school_id]}")
else
@c_shixuns = Subject.where("0=0")
end
if params[:status] && params[:status]!=''
@c_shixuns= @c_shixuns.where(:status =>status)
end
if search.blank?
@c_shixuns = @c_shixuns
else
if "u_name" == keyword
# user_id = User.where("concat(lastname, firstname) like '%#{search}%'")
@c_shixuns = @c_shixuns.includes(:user).where("concat(users.lastname, users.firstname) like '%#{search}%'")
else
@c_shixuns = @c_shixuns.where("name like '%#{search}%'")
end
end
unless params[:school_id] || params[:search] || params[:keyword] || params[:status]
user_exs = UserExtensions.where(:user_id => @c_shixuns.map(&:user_id))
@schools = School.where(:id => user_exs.map(&:school_id))
end
if params[:search_homepage_show]
@c_shixuns = @c_shixuns.where(:homepage_show => params[:search_homepage_show].to_i)
end
@c_shixuns = @c_shixuns.order("subjects.created_at #{@sx_order}")
@page = (params['page'] || 1).to_i
@c_shixuns_count = @c_shixuns.count
@limit = 20
@c_shixuns_pages = Paginator.new @c_shixuns_count, @limit, params['page'] || 1
@c_shixuns = paginateHelper @c_shixuns, @limit
@offset ||= @c_shixuns_pages.offset
respond_to do |format|
format.js
format.html
end
end
def update_repertoire_of_subject
subject = Subject.find(params[:subject_id])
subject.update_attribute(:repertoire_id, params[:rep_id])
render :json =>{ :data => "success"}
end
def update_subject_hidden
@subject = Subject.find(params[:subject_id])
@subject.update_column(:hidden, !@subject.hidden)
end
# 已发布课程实训
def class_publish_shixuns
@menu_type = 4
@sub_type = 3
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
search = params[:search] # 搜索字
keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/课程名搜索
if params[:school_id] && params[:school_id] != '0'
@c_shixuns = Subject.includes(:user => {:user_extensions => []}).where("subjects.status = 2 and user_extensions.school_id = #{params[:school_id]}")
else
@c_shixuns = Subject.where(:status => 2)
end
if params[:beginTime] && params[:beginTime].strip != ""
@c_shixuns = @c_shixuns.where("publish_time >= '#{Time.parse(params[:beginTime])}'")
end
if params[:endTime] && params[:endTime].strip != ""
@c_shixuns = @c_shixuns.where("publish_time <= '#{Time.parse(params[:endTime])}'")
end
if search.blank?
elsif "u_name" == keyword
# 如果用户搜索为空不用遍历user表直接查找所有实训, 有搜索时才查找user
user_id = User.where("concat(lastname, firstname) like '%#{search}%'")
@c_shixuns = @c_shixuns.includes(:user).where("concat(users.lastname, users.firstname) like '%#{search}%'")
else
@c_shixuns= @c_shixuns.where("name like '%#{search}%'")
end
unless params[:school_id] || params[:search] || params[:keyword]
user_exs = UserExtensions.where(:user_id => @c_shixuns.map(&:user_id))
@schools = School.where(:id => user_exs.map(&:school_id))
end
@page = (params['page'] || 1).to_i
@c_shixuns = @c_shixuns.order("subjects.publish_time #{@sx_order}")
@c_shixuns_count = @c_shixuns.count
all_subjects = @c_shixuns.includes(stages: [:stage_shixuns])
Rails.logger.warn("##########all_subjects:#{all_subjects.count}")
@limit = 20
@c_shixuns_pages = Paginator.new @c_shixuns_count, @limit, params['page'] || 1
@offset ||= @c_shixuns_pages.offset
@c_shixuns = paginateHelper @c_shixuns, @limit
respond_to do |format|
format.js
format.html
format.xls {
filename = "已发布实训课程-#{Time.now.strftime('%Y-%m-%d %H:%M:%S')}.xls"
send_data(published_subject_xls(all_subjects), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
# 已发布实训路径首页显示
def subject_homepage_show
if params[:subject_id]
subject = Subject.find params[:subject_id]
subject.update_attributes(:homepage_show => !subject.homepage_show)
end
end
# 导出excel
def export_excel
@course = params[:course]
respond_to do |format|
format.xls {
@course = @course.reorder("#{Tracker.table_name}.position, #{Course.table_name}.id").all
filename = "#{l(:label_course_list_xls)}.xls"
send_data(course_list_xls(@course), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
# 解除ip限制
def cancel_ip_limit
LoginIpInfo.destroy_all
end
# 0 全部1 活动的; 2 已注册; 3 锁定
def users
@menu_type = 7
@sub_type = 1
status = params[:user_status].nil? ? 0 : params[:user_status].to_i
@us_order = params[:us_order].blank? ? "desc" : params[:us_order] # 排序
@order_key = params[:order_key].blank? ? "last_login_on" : params[:order_key] # 排序关键字
condition = (params[:research_condition].nil? || params[:research_condition] == "name") ? "concat(lastname, firstname)" : params[:research_condition]
if 0 == status
if params[:research_condition] == "phone" && params[:research_contents].blank?
@users = User.order("#{@order_key} #{@us_order}")
else
@users = User.where("#{condition} like '%#{params[:research_contents]}%'").order("#{@order_key} #{@us_order}")
end
else
if params[:research_condition] == "phone" && params[:research_contents].blank?
@users = User.where(:status => status).order("#{@order_key} #{@us_order}")
else
@users = User.where("status = #{status} and #{condition} like '%#{params[:research_contents]}%'").order("#{@order_key} #{@us_order}")
end
end
if params[:school] && params[:school] != ''
school_name = params[:school]
school = School.where("name like '%#{school_name}%'")
school_id = school.map(&:id)
user_id = UserExtensions.where(:school_id => school_id).map(&:user_id)
@users = @users.where(:id => user_id).order("#{@order_key} #{@us_order}")
end
@page = (params['page'] || 1).to_i
@users_count = @users.count
@limit = 20
@is_remote = true
@users_pages = Paginator.new @users_count, @limit, params['page'] || 1
@offset ||= @users_pages.offset
@users = paginateHelper @users, @limit
respond_to do |format|
format.js
format.html
end
end
# 解锁IP功能
def unlock_user_ip
logger.info("####unlock_user_ip user_id: #{params[:user_id]}")
if params[:user_id]
ip = LoginIpInfo.find_by_user_id(params[:user_id])
ip.destroy if ip
end
end
def shixuns
@menu_type = 3
@sub_type = 1
@sx_status = (params[:status].blank? || params[:status].class == Array) ? [0, 1, 2, 3] : params[:status].to_i # 搜索实训的状态
@keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/实训名搜索
@search = params[:search] # 搜索的字
@tech = params[:tech]
@shixun_tag_id = params[:shixun_tag]
@tech_system = MirrorRepository.where(nil).map(&:type_name).reject(&:blank?).sort()
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order] # 排序
if "u_name" == @keyword
# 如果用户搜索为空不用遍历user表直接查找所有实训, 有搜索时才查找user
if @search.blank?
@shixuns = Shixun.where(:status => @sx_status).order("created_at #{@sx_order}")
else
user_id = User.where("concat(lastname, firstname) like '%#{@search}%'")
@shixuns = Shixun.where(:user_id => user_id, :status => @sx_status).order("created_at #{@sx_order}")
end
else
if params[:keyword] == "sx_name"
@shixuns = Shixun.where("name like '%#{@search}%'").where(:status => @sx_status).order("created_at #{@sx_order}")
else
school_id = School.where("name like '%#{@search}%'").map(&:id)
user_id = UserExtensions.where(:school_id => school_id).map(&:user_id)
@shixuns = Shixun.where(:user_id => user_id).where(:status => @sx_status).order("created_at #{@sx_order}")
end
end
#@shixuns = @shixuns.includes(:mirror_repositories).where("mirror_repositories.name like '%#{@tech}%'") if @tech.present?
if @tech.present?
shixuns_id = MirrorRepository.where(:type_name => @tech).first.try(:shixuns)
@shixuns = @shixuns.where(:id => shixuns_id)
end
# shixun_tag_id: -1时 搜索没有技术标签的实训
if @shixun_tag_id.present?
if @shixun_tag_id.to_i == -1
shixuns_id = ShixunTagRepertoire.where(nil).map(&:shixun_id)
if shixuns_id.present?
shixuns_id = @shixuns.map(&:id) - shixuns_id
@shixuns = @shixuns.where(:id => shixuns_id)
end
else
shixuns_id = ShixunTagRepertoire.where(:tag_repertoire_id => @shixun_tag_id).map(&:shixun_id)
@shixuns = @shixuns.where(:id => shixuns_id)
end
end
@shixun_xls = @shixuns
@edit_sx_num = Shixun.where(:status => 0).count
@audit_sx_num = Shixun.where(:status => 1).count
@publish_sx_num =Shixun.where(:status => 2).count
@close_sx_num = Shixun.where(:status => 3).count
@page = (params['page'] || 1).to_i
@shixuns_count = @shixuns.count
@limit = 20
@shixuns_pages = Paginator.new @shixuns_count, @limit, params['page'] || 1
@offset ||= @shixuns_pages.offset
@shixuns = paginateHelper @shixuns, @limit
@shixun_tags = TagRepertoire.where(nil).order("name asc")
respond_to do |format|
format.js
format.html
format.xls{
# @export_shixun_task = @export_shixun_task.all
filename = "实训详情_#{Time.now.strftime('%Y-%m-%d %H:%M:%S')}.xls"
send_data(shixun_list_xls(@shixun_xls), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
def shixun_setting_list
@menu_type = 3
@sub_type = 2
@sx_status = (params[:status].blank? || params[:status].class == Array) ? [0, 1, 2, 3] : params[:status].to_i # 搜索实训的状态
@keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/实训名搜索
@search = params[:search] # 搜索的字
@tech = params[:tech]
@shixun_tag_id = params[:shixun_tag]
@tech_system = MirrorRepository.where(nil).map(&:type_name).reject(&:blank?).sort()
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order] # 排序
close = params[:close] # 关闭实训,参数是实训的Id
unless close.blank?
Shixun.find(close).update_attributes(:status => 3, :closer_id => User.current.id, :end_time => Time.now)
end
if "u_name" == @keyword
# 如果用户搜索为空不用遍历user表直接查找所有实训, 有搜索时才查找user
if @search.blank?
@shixuns = Shixun.where(:status => @sx_status).order("created_at #{@sx_order}")
else
user_id = User.where("concat(lastname, firstname) like '%#{@search}%'")
@shixuns = Shixun.where(:user_id => user_id, :status => @sx_status).order("created_at #{@sx_order}")
end
else
if params[:keyword] == "sx_name"
@shixuns = Shixun.where("name like '%#{@search}%'").where(:status => @sx_status).order("created_at #{@sx_order}")
else
school_id = School.where("name like '%#{@search}%'").map(&:id)
user_id = UserExtensions.where(:school_id => school_id).map(&:user_id)
@shixuns = Shixun.where(:user_id => user_id).where(:status => @sx_status).order("created_at #{@sx_order}")
end
end
#@shixuns = @shixuns.includes(:mirror_repositories).where("mirror_repositories.name like '%#{@tech}%'") if @tech.present?
if @tech.present?
shixuns_id = MirrorRepository.where(:type_name => @tech).first.try(:shixuns)
@shixuns = @shixuns.where(:id => shixuns_id)
end
# shixun_tag_id: -1时 搜索没有技术标签的实训
if @shixun_tag_id.present?
if @shixun_tag_id.to_i == -1
shixuns_id = ShixunTagRepertoire.where(nil).map(&:shixun_id)
if shixuns_id.present?
shixuns_id = @shixuns.map(&:id) - shixuns_id
@shixuns = @shixuns.where(:id => shixuns_id)
end
else
shixuns_id = ShixunTagRepertoire.where(:tag_repertoire_id => @shixun_tag_id).map(&:shixun_id)
@shixuns = @shixuns.where(:id => shixuns_id)
end
end
if params[:can_copy]
@shixuns = @shixuns.where(:can_copy => params[:can_copy].to_i)
end
if params[:webssh]
@shixuns = @shixuns.where(:webssh => params[:webssh].to_i)
end
if params[:hidden]
@shixuns = @shixuns.where(:hidden => params[:hidden].to_i)
end
if params[:homepage_show]
@shixuns = @shixuns.where(:homepage_show => params[:homepage_show].to_i)
end
if params[:task_pass]
@shixuns = @shixuns.where(:task_pass => params[:task_pass].to_i)
end
if params[:code_hidden]
@shixuns = @shixuns.where(:code_hidden => params[:code_hidden].to_i)
end
@shixun_xls = @shixuns
@edit_sx_num = Shixun.where(:status => 0).count
@audit_sx_num = Shixun.where(:status => 1).count
@publish_sx_num =Shixun.where(:status => 2).count
@close_sx_num = Shixun.where(:status => 3).count
@page = (params['page'] || 1).to_i
@shixuns_count = @shixuns.count
@limit = 20
@shixuns_pages = Paginator.new @shixuns_count, @limit, params['page'] || 1
@offset ||= @shixuns_pages.offset
@shixuns = paginateHelper @shixuns, @limit
@shixun_tags = TagRepertoire.where(nil).order("name asc")
respond_to do |format|
format.js
format.html
format.xls{
# @export_shixun_task = @export_shixun_task.all
filename = "实训详情_#{Time.now}.xls"
send_data(shixun_list_xls(@shixun_xls), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
def update_shixun_task_pass
shixun = Shixun.find(params[:shixun_id])
shixun.update_column(:task_pass, !shixun.task_pass)
end
def update_shixun_code_hidden
shixun = Shixun.find(params[:shixun_id])
shixun.update_column(:code_hidden, !shixun.code_hidden)
end
def update_shixun_excute_time
shixun = Shixun.find(params[:shixun_id])
shixun.update_column(:excute_time, params[:excute_time].strip == "" ? nil : params[:excute_time].strip)
end
def shixun_update_image_text
image_text = params[:values].strip
shixun = Shixun.find params[:id]
shixun.update_column(:image_text, image_text)
render :json => {success: "true"}
end
def build_shixun_and_repertore_relationship
logger.info("#################{params}")
tag_id = params[:tag_id].to_i
shixun_id = params[:shixun_id]
status = params[:status].to_i
shixun_tags_count = ShixunTagRepertoire.where(:shixun_id => shixun_id).count
logger.info("#################{shixun_tags_count}")
if shixun_tags_count > 3
render :json => {data: "error"}
else
shixun_tags = ShixunTagRepertoire.where(:shixun_id => shixun_id, :tag_repertoire_id => tag_id).first
if status == 0
shixun_tags.destroy if shixun_tags.present?
else
if shixun_tags.present?
shixun_tags.update_attribute(:tag_repertoire_id, tag_id)
else
ShixunTagRepertoire.create!(:tag_repertoire_id => tag_id, :shixun_id => shixun_id)
end
end
render :json => {data: "success"}
end
end
def update_shixun_hidden
@shixun = Shixun.find(params[:shixun_id])
@shixun.update_column(:hidden, !@shixun.hidden)
end
# 已发布的实训
def publish_shixuns
logger.info("####################{params}")
@menu_type = 3
@sub_type = 3
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order] # 排序
index = params[:index] # 排序
@search = params[:search] # 搜索字
@keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/实训名搜索
@tech = params[:tech]
@beginTime = params[:beginTime]
@endTime = params[:endTime]
@tech_system = MirrorRepository.where(nil).map(&:type_name).reject(&:blank?).sort()
if "u_name" == @keyword
# 如果用户搜索为空不用遍历user表直接查找所有实训, 有搜索时才查找user
if @search.blank?
@shixuns = Shixun.where(:status => 2)
@shixuns = sort_shixun index, @shixuns, @sx_order
else
user_id = User.where("concat(lastname, firstname) like '%#{@search}%'")
@shixuns = Shixun.where(:user_id => user_id, :status => 2)
@shixuns = sort_shixun index, @shixuns, @sx_order
end
else
@shixuns = Shixun.where("name like '%#{@search}%'").where(:status => 2)
@shixuns = sort_shixun index, @shixuns, @sx_order
end
if params[:homepage_show]
@shixuns = @shixuns.where(:homepage_show => params[:homepage_show].to_i)
@shixuns = sort_shixun index, @shixuns, @sx_order
end
if params[:tech] && params[:tech] !=''
@shixuns = @shixuns.where("language like '#{@tech}'")
@shixuns = sort_shixun index, @shixuns, @sx_order
end
if @tech.present?
shixuns_id = MirrorRepository.where(:type_name => @tech).first.try(:shixuns)
@shixuns = @shixuns.where(:id => shixuns_id)
end
if params[:beginTime].present?
logger.info("#############------------------")
endTime = params[:endTime].present? ? params[:endTime] : Time.now
@shixuns = @shixuns.where("publish_time >= ? and publish_time <= ?", params[:beginTime], endTime)
end
if index == '6'
@op_order = @sx_order
@sx_order = ""
else
@sx_order = @sx_order
@op_order = ""
end
@page = (params['page'] || 1).to_i
@shixuns_count = @shixuns.count
@shixun_xls = @shixuns
@limit = 20
@shixuns_pages = Paginator.new @shixuns_count, @limit, params['page'] || 1
@offset ||= @shixuns_pages.offset
@shixuns = paginateHelper @shixuns, @limit
respond_to do |format|
format.js
format.html
format.xls{
filename = "已发布的实训_#{format_time Time.now}.xls"
send_data(publish_shixun_list(@shixun_xls), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
# 实训首页显示
def shixun_homepage_show
if params[:shixun_id]
shixun = Shixun.find params[:shixun_id]
shixun.update_attributes(:homepage_show => !shixun.homepage_show)
end
end
# 允许复制
def shixun_can_copy
if params[:shixun_id]
shixun = Shixun.find params[:shixun_id]
shixun.update_attributes(:can_copy => !shixun.can_copy)
end
end
# 已关闭的实训
def close_shixuns
@menu_type = 3
@sub_type = 4
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order] # 排序
search = params[:search] # 搜索字
keyword = params[:keyword].blank? ? "u_name" : params[:keyword] # 根据姓名/实训名搜索
reopen = params[:reopen] # 从新开启实训,参数是实训的Id
tech = params[:tech]
@tech_system = MirrorRepository.where(nil).map(&:type_name).reject(&:blank?).sort()
unless reopen.blank?
Shixun.find(reopen).update_attribute(:status, 2)
end
if "u_name" == keyword
# 如果用户搜索为空不用遍历user表直接查找所有实训, 有搜索时才查找user
if search.blank?
@shixuns = Shixun.where(:status => 3).order("updated_at #{@sx_order}")
else
user_id = User.where("concat(lastname, firstname) like '%#{search}%'")
@shixuns = Shixun.where(:user_id => user_id, :status => 3).order("updated_at #{@sx_order}")
end
else
@shixuns = Shixun.where("name like '%#{search}%'").where(:status => 3).order("updated_at #{@sx_order}")
end
if params[:tech].present?
shixuns_id = MirrorRepository.where(:type_name => tech).first.try(:shixuns)
@shixuns = @shixuns.where(:id => shixuns_id)
end
@page = (params['page'] || 1).to_i
@shixuns_count = @shixuns.count
@limit = 20
@shixuns_pages = Paginator.new @shixuns_count, @limit, params['page'] || 1
@offset ||= @shixuns_pages.offset
@shixuns = paginateHelper @shixuns, @limit
respond_to do |format|
format.js
format.html
end
end
# 镜像类别图片
def mirror_picture_shixuns
@main_mirror = MirrorRepository.where(nil)
@repertoire = Repertoire.where(nil)
@menu_type = 3
@sub_type = 7
search = params[:search]
if params[:search] && params[:search] != ''
@main_mirror = @main_mirror.where("type_name like '%#{search}%'")
end
@page = (params['page'] || 1).to_i
@main_mirror_count = @main_mirror.count
@limit = 20
@main_mirror_pages = Paginator.new @main_mirror_count, @limit, params['page'] || 1
@offset ||= @main_mirror_pages.offset
@main_mirror = paginateHelper @main_mirror, @limit
respond_to do |format|
format.js
format.html
end
end
def update_mirror_picture
if params[:res] == "1"
mirror = MirrorRepository.where(:id => params[:mirror_id]).first
MirrorRepository.where(:id => params[:mirror_id]).update_all(:repertoire_id => params[:use_scope], :sub_repertoire_id => nil)
else
MirrorRepository.where(:id => params[:mirror_id]).update_all(:sub_repertoire_id => params[:use_scope])
end
redirect_to mirror_picture_shixuns_managements_path(:page => params[:page])
end
# 实训成员列表
def shixun_member
@menu_type = 3
@sub_type = 6
@shixun_member = Myshixun.where("0=0").order("created_at desc")
keyword = params[:keyword]
search = params[:search]
member = params[:member]
if search.blank?
@shixun_member = @shixun_member
else
if "u_name" == keyword
user_id = User.where("concat(lastname, firstname) like '%#{search}%'")
@shixun_member = @shixun_member.where(:user_id => user_id)
elsif keyword == "u_id"
user_id = User.where("login like '%#{search}%'")
@shixun_member = @shixun_member.where(:user_id => user_id)
elsif keyword == "sx_name"
@shixun_member = @shixun_member.joins(:shixun).where("shixuns.name like '%#{search}%'")
else
school_id = School.where("name like '%#{search}%'").blank? ? "(-1)" : "(" + School.where("name like '%#{search}%'").map(&:id).join(",") + ")"
user_id = UserExtensions.where("school_id in #{school_id}").blank? ? "(-1)" : "(" + UserExtensions.where("school_id in #{school_id}").map(&:user_id).join(",") + ")"
@shixun_member = @shixun_member.where("user_id in #{user_id}")
end
end
if member && member != ''
user_id = User.where("concat(lastname, firstname) like '%#{member}%'").blank? ? "(-1)" : "(" + User.where("concat(lastname, firstname) like '%#{member}%'").map(&:id).join(",") + ")"
@shixun_member = @shixun_member.joins(:shixun).where("shixuns.user_id in #{user_id}")
end
@page = (params['page'] || 1).to_i
@shixun_member_count = @shixun_member.count
@limit = 20
@is_remote = true
@shixun_member_pages = Paginator.new @shixun_member_count, @limit, params['page'] || 1
@offset ||= @shixun_member_pages.offset
@shixun_member = paginateHelper @shixun_member, @limit
respond_to do |format|
format.js
format.html
end
end
def users_trial
@menu_type = 7
@sub_type = 2
@sx_order = params[:sx_order].blank? ? "desc" : params[:sx_order]
sql =
if params[:t].to_i == 1 && params[:e].to_i == 1
"status = 1 and homepage_teacher = 1 and homepage_engineer = 1"
elsif params[:t].to_i == 1
"status = 1 and homepage_teacher = 1"
elsif params[:e].to_i == 1
"status = 1 and homepage_engineer = 1"
else
"status = 1"
end
@users = User.where("#{sql}").includes(:apply_actions, user_extensions: [:department, :school]).order("last_login_on #{@sx_order}")
@has_cer_count = User.where(:status => 1, :certification => 1).count
@reject_cer_count = User.where(:status => 1, :certification => 2).count
@deal_cer_count = ApplyAction.where(:status => 0).select("distinct user_id").count
time = Time.at(Time.now.to_i - 86400)
cer = UserDayCertification.where("created_at > '#{time}'").pluck(:user_id)
cer_ids = cer.join(",")
@trial_cer_count = cer.blank? ? 0 : User.where("status = 1 and certification != 1 and id in (#{cer_ids})").count
apply = ApplyAction.where(:container_type => "TrialAuthorization").pluck(:user_id)
apply_ids = apply.join(",")
@nonn_cer_count = apply.blank? ? 0 : User.where("status = 1 and certification = 0 and id not in (#{apply_ids}) ").count
@page = (params['page'] || 1).to_i
@users_count = @users.count
@limit = 20
@users_pages = Paginator.new @users_count, @limit, params['page'] || 1
@offset ||= @users_pages.offset
@users = paginateHelper @users, @limit
end
def user_homepage_show
user = User.find params[:user_id]
if params[:homepage] == "homepage_teacher"
user.update_attributes(:homepage_teacher => !user.homepage_teacher)
else
user.update_attributes(:homepage_engineer => !user.homepage_engineer)
end
end
def shixun_sigle_training
begin
shixun = Shixun.find(params[:shixun_id])
shixun.update_column(:sigle_training, !shixun.sigle_training)
render :json => {:status => 1}
rescue Exception => e
logger.error(e.message)
end
end
def import_course_members
attachments = params[:attachments]
@status = 0
member_count = 0
attachments.each do |attachment|
attachment = Attachment.find_by_token_only(attachment[1]['token'])
attachment.container_id = User.current.id
attachment.container_type = "ImportCourseMember"
attachment.save
path = attachment.disk_directory
name = attachment.disk_filename
if name.split(".").last == "xls"
# begin
xls = Roo::Spreadsheet.open("files/#{path}/#{name}",extension: :xls)
worksheet = xls.sheet(0)
rows = worksheet.last_row #最后一行数
if rows < 2
@status = 0
@message = "请按照模板格式导入"
else
for row in 2 .. rows
student_id = worksheet.cell(row, 1)
student_id = student_id.is_a?(Float) ? student_id.to_i : student_id
member_role = worksheet.cell(row, 4).to_i
course_id = worksheet.cell(row, 3)
group_name = worksheet.cell(row, 5)
if student_id && member_role && [9, 7, 10].include?(member_role) && course_id
user = User.find_by_sql("SELECT u.* FROM `users` u, `user_extensions` ue where u.id = ue.user_id and
ue.student_id = '#{student_id}' and ue.school_id= 2458").first
course = Course.where(:id => course_id).first
# 判断用户和课堂是否都存在,存在则判断该用户是否已是课堂成员,不是则加入课堂
if user.present? && course.present?
course_group = CourseGroup.where(:course_id => course.id, :name => group_name).first ||
CourseGroup.create(:name => group_name, :course_id => course.id) if group_name
member = course.members.where(:user_id => user.id).first
# 如果已是课堂成员且是学生身份and不在指定的分班则移动到该分班
if member.present? && member.member_roles.pluck(:role_id).include?(10) && member.course_group_id != course_group.try(:id).to_i
member.update_column("course_group_id", course_group.try(:id).to_i)
member_count += 1
elsif !member.present?
member = Member.new(:role_ids => [member_role], :user_id => user.id)
if member_role == 10
StudentsForCourse.create(:student_id => user.id, :course_id => course.id)
end
Tiding.create(:user_id => user.id, :trigger_user_id => course.tea_id, :container_id => course.id, :container_type => 'TeacherJoinCourse',
:belong_container_id => course.id, :belong_container_type => "Course", :tiding_type => "System", :extra => member_role)
member.course_group_id = course_group.try(:id).to_i
course.members << member
member_count += 1
end
end
end
end
@status = 1
@message = "已导入/更新#{member_count}个成员"
end
# rescue
# @status = 0
# @message = "文件内容无法读取"
# end
else
@status = 0
@message = "只支持xls文件的导入"
end
attachment.destroy
end
end
def import_student_accounts
attachments = params[:attachments]
@status = 0
account_count = 0
attachments.each do |attachment|
attachment = Attachment.find_by_token_only(attachment[1]['token'])
attachment.container_id = User.current.id
attachment.container_type = "ImportStudentAccount"
attachment.save
path = attachment.disk_directory
name = attachment.disk_filename
if name.split(".").last == "xls"
begin
xls = Roo::Spreadsheet.open("files/#{path}/#{name}",extension: :xls)
worksheet = xls.sheet(0)
rows = worksheet.last_row #最后一行数
if rows < 4
@status = 0
@message = "请按照模板格式导入"
else
school_id = worksheet.cell(1, 1)
prefix = worksheet.cell(2, 1)
for row in 4 .. rows
if worksheet.cell(row, 4) && [0, 1, 2].include?(worksheet.cell(row, 4).to_i)
student_id = worksheet.cell(row, 1).is_a?(Float) ? worksheet.cell(row, 1).to_i : worksheet.cell(row, 1)
user = User.find_by_sql("SELECT u.* FROM `users` u, `user_extensions` ue where u.id = ue.user_id and
ue.student_id = '#{student_id}' and ue.school_id= #{school_id.to_i}").first
school = School.where(:id => school_id).first
# 用户不存在则创建账号
if school.present?
department = Department.where(:school_id => school.id, :name => worksheet.cell(row, 3)).first
department = Department.create(:school_id => school.id, :name => worksheet.cell(row, 3), :is_auth => 1) if !department.present?
if !user.present?
user = User.new
user.admin = false
user.activate
user.login = prefix + student_id.to_s
user.lastname = worksheet.cell(row, 2)
user.nickname = worksheet.cell(row, 2)
user.professional_certification = 1
user.certification = 1
user.grade = 0
user.password = "12345678"
if user.save
ue = UserExtensions.new(:user_id => user.id, :gender => 0, :school_id => school_id, :location => school.province,
:location_city => school.city, :identity => worksheet.cell(row, 4), :student_id => student_id,
:department_id => department.try(:id))
if worksheet.cell(row, 4) && worksheet.cell(row, 4).to_i == 0
ue.technical_title = ["教授", "副教授", "讲师", "助教"].include?(worksheet.cell(row, 5)) ? worksheet.cell(row, 5) : "讲师"
elsif worksheet.cell(row, 4) && worksheet.cell(row, 4).to_i == 2
ue.technical_title = ["企业管理者", "部门管理者", "高级工程师", "工程师", "助理工程师"].include?(worksheet.cell(row, 5)) ? worksheet.cell(row, 5) : "助理工程师"
end
ue.save
account_count += 1
end
elsif user.present?
user.update_attributes(:certification => 1, :status => 1, :lastname => worksheet.cell(row, 2), :professional_certification => 1)
ue = user.user_extensions
if ue.present?
if worksheet.cell(row, 4) && worksheet.cell(row, 4).to_i == 0
technical_title = ["教授", "副教授", "讲师", "助教"].include?(worksheet.cell(row, 5)) ? worksheet.cell(row, 5) : "讲师"
elsif worksheet.cell(row, 4) && worksheet.cell(row, 4).to_i == 2
technical_title = ["企业管理者", "部门管理者", "高级工程师", "工程师", "助理工程师"].include?(worksheet.cell(row, 5)) ? worksheet.cell(row, 5) : "助理工程师"
end
ue.update_attributes(:identity => worksheet.cell(row, 4), :student_id => student_id, :department_id => department.try(:id), :technical_title => technical_title)
end
account_count += 1
end
end
end
end
@status = 1
@message = "已导入/更新#{account_count}个账号"
end
rescue
@status = 0
@message = "文件内容无法读取"
end
else
@status = 0
@message = "只支持xls文件的导入"
end
attachment.destroy
end
end
# 自动授权列表
def auto_users_trial
@menu_type = 7
@sub_type = 3
# @apply_action = School.where(:auto_users_trial => 1).order('authorization_time desc')
@apply_action = School.find_by_sql("select s.*, count(ue.user_id) as user_count From schools s left join user_extensions ue on s.id = ue.school_id
where s.auto_users_trial =1 group by s.id order by user_count desc;")
@auto_school_ids = @apply_action.empty? ? "(-1)" : "(" + @apply_action.map(&:id).join(",") + ")"
@page = (params['page'] || 1).to_i
@apply_action_count = @apply_action.count
@limit = 20
@is_remote = true
@apply_action_pages = Paginator.new @apply_action_count, @limit, params['page'] || 1
@offset ||= @apply_action_pages.offset
@apply_action = paginateHelper @apply_action, @limit
respond_to do |format|
format.html
format.js
end
end
def search_authorization_school
school_name = params[:contents]
@sx_order = params[:order]
@apply_action = School.authorization.where("name like '%#{school_name}%'").order("authorization_time #{@sx_order}")
@page = (params['page'] || 1).to_i
@apply_action_count = @apply_action.count
@limit = 20
@is_remote = true
@apply_action_pages = Paginator.new @apply_action_count, @limit, params['page'] || 1
@offset ||= @apply_action_pages.offset
@apply_action = paginateHelper @apply_action, @limit
end
# 过关任务模板
def editmd_template
@menu_type = 3
@samples_type = params[:samples_type]
@samples_type == "taskPass" ? @sub_type = 1 : ( @samples_type == "introduction" ? @sub_type = 2 : @sub_type = 3 )
@sample = PlatformSample.where(:samples_type => @samples_type).first
unless params[:template].nil?
if @sample.nil?
@sample = PlatformSample.create(:samples_type => @samples_type, :contents => params[:template])
else
@sample.update_attribute(:contents, params[:template])
end
end
respond_to do |format|
format.html
format.js
end
end
# 新课导语模板
def course_guide_template
@menu_type = 12
@sub_type = 5
@samples_type = params[:samples_type]
@sample = PlatformSample.where(:samples_type => @samples_type).first
if request.post?
unless params[:platform_sample][:contents].nil?
if @sample.nil?
PlatformSample.create(:samples_type => @samples_type, :contents => params[:platform_sample][:contents])
else
@sample.update_attribute(:contents, params[:platform_sample][:contents])
end
end
end
@sample = @sample || PlatformSample.new
respond_to do |format|
format.html
end
end
# 实训评分
def shixun_quality_score
@menu_type = 12
@sub_type = 6
@shixun_scores = ScoreSet.where(nil).order("created_at asc")
respond_to do |format|
format.js
format.html
end
end
def new_score_sets
name = params[:type_name]
level = params[:level]
lower = params[:lower]
upper = params[:upper]
ActiveRecord::Base.transaction do
begin
score_set = ScoreSet.create!(:name => name)
level.each_with_index do |l, index|
ScoreIndicatorQuality.create!(:name => l, :upper_limit => upper[index], :lower_limit => lower[index], :score_set_id => score_set.id, :position => index+1) if l.present?
end
rescue Exception => e
logger.error("new_score_sets failed #{e}")
raise ActiveRecord::Rollback
end
end
redirect_to shixun_quality_score_managements_path
end
def new_score_indicator
@shixun_scores = ScoreSet.find(params[:score_set_id])
@score_qualities = @shixun_scores.score_indicator_qualities
end
def edit_score_indicator
@indicator = ScoreIndicator.find(params[:score_indicator_id])
@shixun_scores = @indicator.score_set
@score_qualities = @shixun_scores.score_indicator_qualities
end
def create_score_indicator
score_set_id = params[:score_set_id]
name = params[:name]
description = params[:description]
desc_name = params[:description_name]
scale = params[:scale]
ActiveRecord::Base.transaction do
begin
indicator = ScoreIndicator.create!(:name => name, :score_set_id => score_set_id, :scale => scale, :description => description)
desc_name.each_with_index do |name, index|
ScoreQualityDescription.create!(:name => name, :score_indicator_id => indicator.id, :position => index+1)
end
rescue Exception => e
logger.error("create_score_indicator failed #{e}")
raise ActiveRecord::Rollback
end
end
redirect_to shixun_quality_score_managements_path
end
def update_score_indicator
score_indicator_id = params[:score_indicator_id]
name = params[:name]
description = params[:description]
scale = params[:scale]
description_name = params[:description_name]
@indicator = ScoreIndicator.find(score_indicator_id)
ActiveRecord::Base.transaction do
begin
if name != @indicator.name || description != @indicator.description || scale != @indicator.scale
@indicator.update_attributes(:name => name, :description => description, :scale => scale) if name.present?
end
description_name.each_with_index do |name, index|
des = @indicator.score_quality_descriptions.where(:position => index+1).first
if name != des.try(:name)
if des.present?
des.update_attribute(:name, name)
else
ScoreQualityDescription.create!(:name => name, :score_indicator_id => @indicator.id, :position => index+1)
end
end
end
redirect_to shixun_quality_score_managements_path
rescue Exception => e
logger.error("update_score_indicator failed #{e}")
raise ActiveRecord::Rollback
end
end
end
def edit_score_set
@shixun_score = ScoreSet.find(params[:score_set_id])
@qualities = @shixun_score.score_indicator_qualities
end
def update_score_sets
score_set_name = params[:type_name]
qualities_id = params[:quality]
level = params[:level]
create_level = params[:create_level]
lower = params[:lower]
create_lower = params[:create_lower]
upper = params[:upper]
create_upper = params[:create_upper]
shixun_score = ScoreSet.find(params[:score_set_id])
quality_id = shixun_score.score_indicator_qualities.map(&:id)
delete_quality_id = quality_id - qualities_id.map(&:to_i)
ActiveRecord::Base.transaction do
begin
# 更新Score_set
if shixun_score.name != score_set_name && score_set_name.present?
shixun_score.update_attribute(:name, score_set_name)
end
# 更新score_indicator_quality
qualities_id.each_with_index do |id, index|
quality = ScoreIndicatorQuality.find(id)
quality.update_attributes(:name => level[index],
:lower_limit => lower[index],
:upper_limit => upper[index],
:position => index + 1) if level[index].present?
end
# 删除score_indicator_quality
delete_qualities = ScoreIndicatorQuality.where(:id => delete_quality_id)
delete_qualities.destroy_all if delete_qualities.present?
# 创建新增score_indicator_quality
index_count = qualities_id.size
create_level.try(:each_with_index) do |name, index|
ScoreIndicatorQuality.create!(:name => name,
:lower_limit => create_lower[index],
:upper_limit => create_upper[index],
:position => index_count + index + 1, :score_set_id => shixun_score.id) if create_lower[index].present?
end
# 删除超出position的score_indicator_descrition
max_position = shixun_score.score_indicator_qualities.maximum(:position)
shixun_score.score_indicators.each do |indicator|
description = ScoreQualityDescription.where("score_indicator_id = ? and position > ?", indicator.id, max_position)
description.destroy_all if description.present?
end
redirect_to shixun_quality_score_managements_path
rescue Exception => e
logger.error("update_score_sets failed #{e}")
raise ActiveRecord::Rollback
end
end
end
def delete_score_set
score_set = ScoreSet.find(params[:score_set_id])
score_set.destroy
redirect_to shixun_quality_score_managements_path
end
def delete_score_indicator
indicator = ScoreIndicator.find(params[:score_indicator_id])
indicator.destroy
redirect_to shixun_quality_score_managements_path
end
# 添加
def create_auto_users_trial
school = School.find params[:school]
school.update_attributes(:auto_users_trial => 1, :authorization_time => Time.now)
user_exs = UserExtensions.where(:school_id => params[:school])
day_cer = UserDayCertification.where(:user_id => user_exs.map(&:user_id))
users = User.where(:id => day_cer.map(&:user_id))
users.update_all("certification = 1")
ApplyAction.where(:user_id => users.map(&:id), :container_type => "TrialAuthorization", :status => 0).update_all(:status => 1)
redirect_to auto_users_trial_managements_path
end
# 删除
def update_auto_users_trial
School.where(:id => params[:school]).update_all(:auto_users_trial => 0)
redirect_to auto_users_trial_managements_path
end
def search_user
if params[:member_ids] && params[:trial_whether] == "trial_agree"
aUser = User.where(:id => params[:member_ids]).includes(:user_extensions)
aUser.update_all(:certification => 1)
# 授权的教师加入示例课堂
aUser.each do |user|
join_ex_course(user) if user.user_extensions.identity == 0
end
apply_user = ApplyAction.where(:user_id => params[:member_ids], :container_type => "TrialAuthorization")
apply_user.update_all(:status => 1) unless apply_user.blank?
elsif params[:member_ids] && params[:trial_whether] == "trial_cancel"
User.where(:id => params[:member_ids]).update_all(:certification => 0)
apply_user = ApplyAction.where(:user_id => params[:member_ids], :container_type => "TrialAuthorization")
apply_user.update_all(:status => 2) unless apply_user.blank?
end
if params[:member_ids] && params[:occupation] == "occupation_agree"
User.where(:id => params[:member_ids]).update_all(:professional_certification => true)
apply_user = ApplyUserAuthentication.where(:user_id => params[:member_ids], :auth_type => 2)
unless apply_user.blank?
apply_user.update_all(:status => 1)
end
elsif params[:member_ids] && params[:realname] == "realname_agree"
User.where(:id => params[:member_ids]).update_all(:authentication => true)
apply_user = ApplyUserAuthentication.where(:user_id => params[:member_ids], :auth_type => 1)
unless apply_user.blank?
apply_user.update_all(:status => 1)
end
elsif params[:member_ids] && params[:occupation] == "occupation_cancel"
users = User.where(:id => params[:member_ids])
users.update_all(:professional_certification => false)
# 取消了职业认证给用户发消息
users.each do |user|
Tiding.create(:user_id => user.id, :trigger_user_id => 0, :container_id => user.id, :container_type =>'CancelUserProCertification', :belong_container_id => user.id, :belong_container_type =>'User', :tiding_type => "System")
end
apply_user = ApplyUserAuthentication.where(:user_id => params[:member_ids], :auth_type => 2)
unless apply_user.blank?
apply_user.update_all(:status => 2)
end
elsif params[:member_ids] && params[:realname] == "realname_cancel"
users = User.where(:id => params[:member_ids])
users.update_all(:authentication => false)
# 取消了实名认证给用户发消息
users.each do |user|
Tiding.create(:user_id => user.id, :trigger_user_id => 0, :container_id => user.id, :container_type =>'CancelUserAuthentication', :belong_container_id => user.id, :belong_container_type =>'User', :tiding_type => "System")
end
apply_user = ApplyUserAuthentication.where(:user_id => params[:member_ids], :auth_type => 1)
unless apply_user.blank?
apply_user.update_all(:status => 2)
end
end
all_user_ids = User.where(:status => 1).pluck(:id)
if params[:trial] == "-1"
apply = ApplyAction.where(:container_type => "TrialAuthorization").pluck(:user_id)
apply_id = apply.blank? ? -1 : "(" + apply.join(",") + ")"
apply_user_id = User.where("status = 1 and certification = 0 and id not in #{apply_id} ").pluck(:id)
elsif params[:trial] == "-2"
apply_user_id = all_user_ids
elsif params[:trial] == "0"
apply_user_id = ApplyAction.where(:status => 0).pluck(:user_id)
elsif params[:trial] == "3"
time = Time.at(Time.now.to_i - 86400)
user_cer = UserDayCertification.where("created_at > '#{time}'").pluck(:user_id)
cer_id = user_cer.blank? ? "(-1)" : "(" + user_cer.map{|a| a.user_id}.join(",") + ")"
apply_user_id = User.where("status = 1 and certification != 1 and id in #{cer_id} ").pluck(:id)
else
apply_user_id = User.where(:status => 1, :certification => params[:trial]).pluck(:id)
end
if params[:school] == ""
s_user_id = all_user_ids
else
school_ids = School.where("name like '%#{params[:school]}%'").pluck(:id)
s_user_id = UserExtensions.where(:school_id => school_ids).pluck(:user_id)
end
if params[:department] == ""
d_user_id = all_user_ids
else
dep_ids = Department.where("name like '%#{params[:department]}%'").pluck(:id)
d_user_id = UserExtensions.where(:department_id => dep_ids).pluck(:user_id)
end
ide_user_id = all_user_ids
if params[:identity] == "1" || (params[:identity] == "0" && params[:te_technical_title] == "0") || (params[:identity] == "2" && params[:pro_technical_title] == "0")
ide_user_id = UserExtensions.where("identity = #{params[:identity]}").pluck(:user_id)
elsif (params[:identity] == "0" && params[:te_technical_title] != "0") || (params[:identity] == "2" && params[:pro_technical_title] != "0")
technical_title = params[:identity] == "0" ? params[:te_technical_title] : params[:pro_technical_title]
ide_user_id = UserExtensions.where("identity = #{params[:identity]} and technical_title = '#{technical_title}'").pluck(:user_id)
end
if params[:student_id] && params[:student_id] != ''
stu_user_id = UserExtensions.where("student_id like '%#{params[:student_id]}%'").pluck(:user_id)
else
stu_user_id = all_user_ids
end
user_id = s_user_id & d_user_id & apply_user_id & stu_user_id & ide_user_id
sql = ""
sql =
if params[:research_condition] == "name"
"concat(lastname, firstname) like '%#{params[:research_contents]}%'"
elsif params[:research_condition] == "email"
"mail like '%#{params[:research_contents]}%'"
elsif params[:research_condition] == "phone"
"phone like '%#{params[:research_contents]}%'"
elsif params[:research_condition] == "nickname"
if params[:research_contents].present?
"nickname like '%#{params[:research_contents]}%'"
end
elsif params[:research_condition] == "login"
params[:research_contents].present? ? "login like '%#{params[:research_contents]}%'" : ""
end
@users = User.where(:id => user_id).where("#{sql}").includes(:apply_actions, user_extensions: [:department, :school]).order("last_login_on desc")
@xls_users = @users #导出excel用户
@page = (params['page'] || 1).to_i
@users_count = @users.count
@limit = 20
@is_remote = true
@users_pages = Paginator.new @users_count, @limit, params['page'] || 1
@offset ||= @users_pages.offset
@users = paginateHelper @users, @limit
respond_to do |format|
format.js
format.xls{
# @export_shixun_task = @export_shixun_task.all
filename = "用户列表.xls"
send_data(user_list_xls(@xls_users), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
}
end
end
def update_webssh
webssh = params[:status] == "true" ? true : false
@shixuns = Shixun.find(params[:shixun_id])
@shixuns.update_column(:webssh, webssh)
respond_to do |format|
format.js
end
end
def affirm_cancel_auth
user_id = params[:users]
end
# 升级通知
def update_notice
@menu_type = 12
@sub_type = 8
@notice = SystemUpdateNotice.first
end
def edit_update_notice
notice = SystemUpdateNotice.first
if notice.present?
notice.update_attributes(:end_time => params[:end_time], :start_time => params[:start_time], :subject => params[:subject], :notes => params[:notes])
else
notice_type = UserSystemNotice.find_by_sql("select max(notice_type) as max_notice_type from user_system_notices").first.try(:max_notice_type).to_i + 1
SystemUpdateNotice.create(:end_time => params[:end_time], :start_time => params[:start_time], :subject => params[:subject], :notes => params[:notes], :notice_type => notice_type)
end
redirect_to update_notice_managements_path
end
def trial_authorization
@menu_type =10
@sub_type = 2
search = params[:search]
@status = trial_authorization_status(params[:status])
# @status = (params[:status].blank? || params[:status] == "0") ? 0 : [1,2]
if search.blank?
@authorizations = ApplyAction.where(:container_type => "TrialAuthorization", :status => @status).includes(:user)
else
user_id = User.find_by_sql("select id from users where concat(lastname,firstname) like '%#{search}%'")
@authorizations = ApplyAction.where(:container_type => "TrialAuthorization", :status => @status, :user_id => user_id).includes(:user)
end
if params[:sname] && params[:sname] != ''
school_id = School.where("name like '%#{params[:sname]}%'")
user_id = UserExtensions.where(:school_id => school_id).map(&:user_id)
@authorizations = @authorizations.where(:user_id => user_id).order("updated_at desc")
end
@autu_count = @authorizations.count
@limit = 15
@is_remote = true
@autu_pages = Paginator.new @autu_count, @limit, params['page'] || 1
@offset ||= @autu_pages.offset
@authorizations = paginateHelper @authorizations, @limit
respond_to do |format|
format.js
format.html
end
end
# 批量授权
def batch_authorization
end
# params[:type] 1拒绝 0同意
# authentication 会有一个初始值,不同的值代表不同的权限
# REDO: 后面权限改了后,一并要改
def trial_authorization_operation
logger.warn("####trial_authorization_operation: #{format_time(Time.now)}")
apply_action = ApplyAction.find(params[:apply_id])
type = params[:type]
search = params[:search]
if type == "0"
authentication_user = AuthenticationsUsers.where(:user_id => apply_action.user_id).first
if authentication_user.blank?
AuthenticationsUsers.create(:user_id => apply_action.user_id, :authentication_id => 1)
end
begin
logger.warn("trial_authorization_operation begin send: #{format_time(format_time(Time.now))}")
# verification_code = code.sample(6).join
if apply_action.user.phone.present?
status = Trustie::Sms.send(mobile: apply_action.user.phone.to_s, code: '1', send_type:'trial_authorization', user_name:apply_action.user.show_name, result:'已通过')
end
logger.warn("trial_authorization_operation complete send: #{format_time(Time.now)}")
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
# 授权的教师加入示例课堂
join_ex_course(apply_action.user) if apply_action.user.user_extensions.identity == 0
logger.warn("####trial_authorization_operation teacher joined: #{format_time(Time.now)}")
else
begin
# verification_code = code.sample(6).join
if apply_action.user.phone.present?
status = Trustie::Sms.send(mobile: apply_action.user.phone.to_s, code: '1', send_type:'trial_authorization', user_name:apply_action.user.show_name, result:'未通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
end
Tiding.where(:user_id => 1, :trigger_user_id => apply_action.user_id, :container_id => apply_action.id, :container_type => 'ApplyAction', :tiding_type => "Apply", :status => 0).update_all(:status => 1)
Tiding.create(:user_id => apply_action.user_id, :trigger_user_id => 0, :container_id => apply_action.id, :container_type => 'ApplyAction',
:parent_container_id => apply_action.container_id, :parent_container_type => apply_action.container_type, :belong_container_id => apply_action.container_id, :belong_container_type => "User", :tiding_type => "System", :status => type == "0" ? 1 : 2)
apply_action.update_attributes(:status => (params[:type] == "1" ? 2 : 1), :reason => params[:reject_reason], :dealer_id => User.current.id, :noticed => false)
User.where(:id => apply_action.user_id).first.update_attributes(:certification => (params[:type] == "1" ? 2 : 1))
user_id = User.find_by_sql("select id from users where concat(lastname,firstname) like '%#{search}%'")
@authorizations = ApplyAction.where(:container_type => "TrialAuthorization", :status => 0, :user_id => user_id).includes(:user)
@autu_count = @authorizations.count
@limit = 15
@is_remote = true
@autu_pages = Paginator.new @autu_count, @limit, params['page'] || 1
@offset ||= @autu_pages.offset
@authorizations = paginateHelper @authorizations, @limit
respond_to do |format|
format.js
end
end
def index
end
# copy from admin
def identity_authentication
@menu_type = 10
@sub_type = 1
@type = trial_authorization_status(params[:type])
type = params[:type] || 0 # 存在type 就用type 没有就为 0
user_id = User.find_by_sql("select id from users where concat(lastname,firstname) like '%#{params[:name]}%'")
@unapproved_user = ApplyUserAuthentication.where(:status => @type, :user_id => user_id, :auth_type => 1).order("updated_at desc")
if params[:sname] && params[:sname] != ''
school_id = School.where("name like '%#{params[:sname]}%'")
user_id = UserExtensions.where(:school_id => school_id).map(&:user_id)
@unapproved_user = @unapproved_user.where(:user_id => user_id).order("updated_at desc")
end
@unapproved_user_count = @unapproved_user.count
@limit = 15
@is_remote = true
@unapproved_user_pages = Paginator.new @unapproved_user_count, @limit, params['page'] || 1
@offset ||= @unapproved_user_pages.offset
@unapproved_user = paginateHelper @unapproved_user, @limit
respond_to do |format|
format.html
format.js
end
end
def professional_authentication
@menu_type = 10
@sub_type = 7
@type = trial_authorization_status(params[:type])
type = params[:type] || 0 # 存在type 就用type 没有就为 0
user_id = User.find_by_sql("select id from users where concat(lastname,firstname) like '%#{params[:name]}%'")
# @unapproved_user = ApplyUserAuthentication.where(:status => @type, :user_id => user_id, :auth_type => 2).find_by_sql("SELECT s.*, TIMESTAMPDIFF(SECOND, s.updated_at, now()) diff FROM `apply_user_authentications` s order by diff asc")
@unapproved_user = ApplyUserAuthentication.where(:status => @type, :user_id => user_id, :auth_type => 2)
if params[:sname] && params[:sname] != ''
school_id = School.where("name like '%#{params[:sname]}%'")
user_id = UserExtensions.where(:school_id => school_id).map(&:user_id)
@unapproved_user = @unapproved_user.where(:user_id => user_id)
end
if params[:identity] && params[:identity] != "" && params[:identity] != "-1"
user_id = UserExtensions.where(:identity => params[:identity]).map(&:user_id)
@unapproved_user = @unapproved_user.where(:user_id => user_id)
end
@unapproved_user = @unapproved_user.order("updated_at desc")
@unapproved_user_count = @unapproved_user.count
@limit = 15
@is_remote = true
@unapproved_user_pages = Paginator.new @unapproved_user_count, @limit, params['page'] || 1
@offset ||= @unapproved_user_pages.offset
@unapproved_user = paginateHelper @unapproved_user, @limit
respond_to do |format|
format.html
format.js
end
end
# 拒绝身份认证
# copy from admin
def reject_authentication
apply_user = ApplyUserAuthentication.where(:id => params[:apply_id], :auth_type => 1).first
reason = apply_user.update_attributes(:status => 2, :remarks => params[:reject_reason])
=begin
begin
if apply_user.user.phone.present?
status = Trustie::Sms.send(mobile: apply_user.user.phone.to_s, code: '1', send_type:'authentication',user_name:apply_user.user.show_name, result:'未通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
=end
diskfile1 = disk_filename("UserAuthentication", apply_user.user_id) +"ID"
apply_user.update_attributes(:is_delete => true)
File.delete(diskfile1)
apply_user.tidings.where(:tiding_type => "Apply").update_all(:status => 1)
Tiding.create(:user_id => apply_user.user_id ,:trigger_user_id => 0, :container_id => apply_user.id, :container_type => "ApplyUserAuthentication", :belong_container_id => apply_user.user_id, :belong_container_type =>'User', :status => 2, :tiding_type => "System")
render :json => {success: reason}
end
# 同意身份认证
# copy from admin
def agree_authentication
apply_user = ApplyUserAuthentication.where(:id => params[:apply_id], :auth_type => 1).first
user = User.find(apply_user.user_id)
apply_user.update_attribute(:status, 1)
user.update_attribute(:authentication, true)
grade_record = Grade.where(:container_id => user.id, :container_type => "Authentication").first
unless grade_record
user.update_attribute(:grade, user.grade + 500)
Grade.create(:user_id => user.id, :container_id => user.id, :container_type => "Authentication", :score => 500)
end
diskfile1 = disk_filename("UserAuthentication", apply_user.user_id) +"ID"
apply_user.update_attributes(:is_delete => true)
File.delete(diskfile1)
=begin
begin
if apply_user.user.phone.present?
status = Trustie::Sms.send(mobile: apply_user.user.phone.to_s, code: '1', send_type:'authentication',user_name:apply_user.user.show_name, result:'已通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
=end
apply_user.tidings.where(:tiding_type => "Apply").update_all(:status => 1)
Tiding.create(:user_id => apply_user.user_id ,:trigger_user_id => 0, :container_id => apply_user.id, :container_type => "ApplyUserAuthentication", :belong_container_id => apply_user.user_id, :belong_container_type =>'User', :status => 1, :tiding_type => "System")
@unapproved_user = ApplyUserAuthentication.where(:status => 0, :auth_type => 1).order("updated_at desc")
@unapproved_user_count = @unapproved_user.count
@limit = 15
@is_remote = true
@unapproved_user_pages = Paginator.new @unapproved_user_count, @limit, params['page'] || 1
@offset ||= @unapproved_user_pages.offset
@unapproved_user = paginateHelper @unapproved_user, @limit
respond_to do |format|
format.js
end
end
# 拒绝职业认证
def reject_authentication_pro
apply_user = ApplyUserAuthentication.where(:id => params[:apply_id], :auth_type => 2).first
if apply_user.present? && apply_user.status == 0
reason = apply_user.update_attributes(:status => 2, :remarks => params[:reject_reason])
diskfile1 = disk_filename("UserAuthentication", apply_user.user_id) +"PRO"
apply_user.update_attributes(:is_delete => true)
File.delete(diskfile1)
=begin
begin
if apply_user.user.phone.present?
status = Trustie::Sms.send(mobile: apply_user.user.phone.to_s, code: '1', send_type:'authentication_pro',user_name:apply_user.user.show_name, result:'未通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
=end
apply_user.tidings.where(:tiding_type => "Apply").update_all(:status => 1)
Tiding.create(:user_id => apply_user.user_id ,:trigger_user_id => 0, :container_id => apply_user.id, :container_type => "ApplyUserAuthentication", :belong_container_id => apply_user.user_id, :belong_container_type =>'User', :status => 2, :tiding_type => "System")
render :json => {success: reason}
end
end
# 同意职业认证
def agree_authentication_pro
apply_user = ApplyUserAuthentication.where(:id => params[:apply_id], :auth_type => 2).first
user = User.find(apply_user.user_id)
apply_user.update_attribute(:status, 1)
user.update_attribute(:professional_certification, true)
grade_record = Grade.where(:container_id => user.id, :container_type => "Professional").first
unless grade_record
user.update_attribute(:grade, user.grade + 500)
Grade.create(:user_id => user.id, :container_id => user.id, :container_type => "Professional", :score => 500)
end
diskfile1 = disk_filename("UserAuthentication", apply_user.user_id) +"PRO"
apply_user.update_attributes(:is_delete => true)
File.delete(diskfile1)
=begin
begin
if apply_user.user.phone.present?
status = Trustie::Sms.send(mobile: apply_user.user.phone.to_s, code: '1', send_type:'authentication_pro',user_name:apply_user.user.show_name, result:'已通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
=end
apply_user.tidings.where(:tiding_type => "Apply").update_all(:status => 1)
Tiding.create(:user_id => apply_user.user_id ,:trigger_user_id => 0, :container_id => apply_user.id, :container_type => "ApplyUserAuthentication", :belong_container_id => apply_user.user_id, :belong_container_type =>'User', :status => 1, :tiding_type => "System")
@unapproved_user = ApplyUserAuthentication.where(:status => 0, :auth_type => 2).order("updated_at desc")
@unapproved_user_count = @unapproved_user.count
@limit = 15
@is_remote = true
@unapproved_user_pages = Paginator.new @unapproved_user_count, @limit, params['page'] || 1
@offset ||= @unapproved_user_pages.offset
@unapproved_user = paginateHelper @unapproved_user, @limit
respond_to do |format|
format.js
end
end
def subject_authorization
@menu_type = 10
@sub_type = 6
@type = trial_authorization_status params[:type]
@authorizations = ApplyAction.where(:container_type => "ApplySubject", :status => @type).order("created_at desc")
# @subject=Subject.all
@authorizations_count = @authorizations.count
@limit = 15
@is_remote = true
@authorizations_pages = Paginator.new @authorizations_count, @limit, params['page'] || 1
@offset ||= @authorizations_pages.offset
@authorizations = paginateHelper @authorizations, @limit
respond_to do |format|
format.js
format.html
end
end
def shixun_authorization
@menu_type = 10
@sub_type = 5
@type = trial_authorization_status params[:type]
# sql = select * from apply_actions where dealer_id is null
@authorizations = ApplyAction.where(:container_type => "ApplyShixun", :status => @type).order("created_at desc")
search = params[:search]
unless search.blank?
@authorizations = @authorizations.where(:container_id => Shixun.where(:id => @authorizations.map(&:container_id)).where("name like '%#{search}%'").map(&:id)).order("created_at desc")
end
@authorizations_count = @authorizations.count
@limit = 15
@is_remote = true
@authorizations_pages = Paginator.new @authorizations_count, @limit, params['page'] || 1
@offset ||= @authorizations_pages.offset
@authorizations = paginateHelper @authorizations, @limit
respond_to do |format|
format.js
format.html
end
end
# 课程实训发布审批
def deal_subject_authorization
apply_action = ApplyAction.find(params[:apply_id])
type = params[:type].to_i
subject = Subject.find apply_action.container_id
if type == 0 #拒绝
subject.update_column('status', 0)
apply_action.update_attributes(:status => 2, :reason => params[:reject_reason], :dealer_id => User.current.id)
# notes = "您所在团队提交的课程实训发布申请:<a href='#{subject_path(subject)}'>#{subject.name}</a>,审核未通过。<br/>原因:#{params[:reject_reason]}"
# JournalsForMessage.create(:jour_id => subject.user_id, :jour_type => 'Principal', :user_id => User.current.id, :notes => notes, :private => 1, :reply_id => 0)
=begin
begin
# verification_code = code.sample(6).join
if subject.owner.phone.present?
status = Trustie::Sms.send(mobile: subject.owner.phone.to_s, code: '1', send_type:'subject_authorization', name:subject.name, user_name:subject.owner.show_name, result:'未通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
=end
else #同意
subject.update_attributes(:status =>2, :publish_time => Time.now)
apply_action.update_attributes(:status => 1, :dealer_id => User.current.id)
=begin
begin
unless subject.owner.phone.present?
status = Trustie::Sms.send(mobile: subject.owner.phone.to_s, code: '1', send_type:'subject_authorization', name:subject.name, user_name:subject.owner.show_name, result:'已通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
=end
end
Tiding.where(:user_id => 1 ,:trigger_user_id => apply_action.user_id, :container_id => apply_action.id, :container_type => 'ApplyAction', :tiding_type => "Apply", :status => 0).update_all(:status => 1)
Tiding.create(:user_id => apply_action.user_id, :trigger_user_id => 0, :container_id => apply_action.id, :container_type => 'ApplyAction',
:parent_container_id => apply_action.container_id, :parent_container_type => apply_action.container_type, :belong_container_id => apply_action.container_id, :belong_container_type => "Subject", :tiding_type => "System", :status => type == 0 ? 2 : 1)
@authorizations = ApplyAction.where(:container_type => "ApplySubject", :status => 0)
@authorizations_count = @authorizations.count
@limit = 15
@is_remote = true
@authorizations_pages = Paginator.new @authorizations_count, @limit, params['page'] || 1
@offset ||= @authorizations_pages.offset
@authorizations = paginateHelper @authorizations, @limit
respond_to do |format|
format.js
end
end
# 项目实训发布审批
def deal_shixun_authorization
apply_action = ApplyAction.find(params[:apply_id])
type = params[:type].to_i
shixun = Shixun.find apply_action.container_id
shixun_creator = shixun.owner
if type == 0 #拒绝
shixun.update_column('status', 0)
apply_action.update_attributes(:status => 2, :reason => params[:reject_reason], :dealer_id => User.current.id)
=begin
begin
if shixun_creator.phone.present?
status = Trustie::Sms.send(mobile: shixun_creator.phone.to_s, code: '1', send_type:'shixun_authorization', name:shixun.name, user_name:shixun_creator.show_name, result:'未通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
=end
else #同意
# 给实训制作者奖励“金币/经验” (奖励数额:实训关卡的金币的总数)
score = shixun.all_score
grade = Grade.where(:user_id => shixun.user_id, :container_id => shixun.id, :container_type => "shixunPublish").first
if grade.blank? # 防止多条创建
Grade.create(:user_id => shixun.user_id, :container_id => shixun.id, :container_type => "shixunPublish", :score => score)
Experience.create(:user_id => shixun.user_id, :container_id => shixun.id, :container_type => "shixunPublish", :score => score)
shixun_creator.update_attributes(:grade => shixun_creator.grade + score, :experience => shixun_creator.experience + score)
end
shixun.update_column('status', 2)
apply_action.update_attributes(:status => 1, :dealer_id => User.current.id)
shixun = Shixun.where(:id => apply_action.container_id).first
shixun.update_attribute(:publish_time, Time.now)
# 实训通关则给实训制作者相应的金币奖励
shixun_modify_status_without_publish shixun, 1
=begin
begin
if shixun_creator.phone.present?
status = Trustie::Sms.send(mobile: shixun.owner.phone.to_s, code: '1', send_type:'shixun_authorization', name:shixun.name, user_name:shixun.owner.show_name, result:'已通过')
end
rescue => e
Rails.logger.error "发送验证码出错: #{e}"
end
=end
end
Tiding.where(:user_id => 1 ,:trigger_user_id => apply_action.user_id, :container_id => apply_action.id, :container_type => 'ApplyAction', :tiding_type => "Apply", :status => 0).update_all(:status => 1)
Tiding.create(:user_id => apply_action.user_id, :trigger_user_id => 0, :container_id => apply_action.id, :container_type => 'ApplyAction',
:parent_container_id => apply_action.container_id, :parent_container_type => apply_action.container_type, :belong_container_id => apply_action.container_id, :belong_container_type => "Shixun", :tiding_type => "System", :status => type == 0 ? 2 : 1)
@authorizations = ApplyAction.where(:container_type => "ApplyShixun", :status => 0)
@authorizations_count = @authorizations.count
@limit = 15
@is_remote = true
@authorizations_pages = Paginator.new @authorizations_count, @limit, params['page'] || 1
@offset ||= @authorizations_pages.offset
@authorizations = paginateHelper @authorizations, @limit
respond_to do |format|
format.js
end
end
def tech_system
@menu_type = 12
@sub_type = 5
@tech_system = Repertoire.where(nil).order("updated_at asc")
respond_to do |format|
format.js
format.html
end
end
# 创建体系
def create_system
rep_name = params[:repertoire]
sub_rep_name = params[:sub_repertoire]
tags_name = params[:tag_repertoire]
ActiveRecord::Base.transaction do
begin
rep = Repertoire.create!(:name => rep_name)
sub_rep = SubRepertoire.create!(:name => sub_rep_name, :repertoire_id => rep.id)
tags_name.each do |tag|
TagRepertoire.create!(:name => tag, :sub_repertoire_id => sub_rep.id)
end
redirect_to tech_system_managements_path
rescue Exception => e
logger.error("create_system error: #{e}")
raise ActiveRecord::Rollback
end
end
end
# 更新tag_repertores的名称
def update_tag_name
tag = TagRepertoire.find(params[:id])
if params[:name].blank?
tag.destroy
else
if tag.name == params[:name].strip
tag.update_column(:updated_at, Time.now)
else
tag.update_attribute(:name, params[:name])
end
end
render :json => {success: "true"}
end
# 更新sub_repertores的名称
def update_sub_name
sub = SubRepertoire.find(params[:id])
if params[:name].blank?
sub.destroy
else
if sub.name == params[:name].strip
sub.update_column(:updated_at, Time.now)
else
sub.update_attribute(:name, params[:name])
end
end
render :json => {success: "true"}
end
def update_rep_name
rep = Repertoire.find(params[:id])
if params[:name].blank?
rep.destroy
else
if rep.name == params[:name].strip
rep.update_column(:updated_at, Time.now)
else
rep.update_attribute(:name, params[:name])
end
end
render :json => {success: "true"}
end
# type 1表示新建sub_repertoire, 2表示新建tag_repertoire
def create_sub_or_tag_repertoire
type = params[:type].to_i
if type == 1
SubRepertoire.create(:name => params[:name], :repertoire_id => params[:id])
elsif type == 2
TagRepertoire.create(:name =>params[:name], :sub_repertoire_id => params[:id])
end
respond_to do |format|
format.js{redirect_to tech_system_managements_path}
end
end
def delete_sub_tech_system
sub_tech = SubRepertoire.where(:id => params[:sub_res]).first
tech = Repertoire.where(:id => params[:sub_res]).first
if sub_tech.present?
sub_tech.destroy
else
tech.destroy
end
redirect_to tech_system_managements_path
end
def create_tech_system
if params[:index] == "1"
Repertoire.create(:name => params[:res_tech])
else
SubRepertoire.create(:name => params[:sub_tech], :repertoire_id => params[:tech])
end
redirect_to tech_system_managements_path
end
def rename_tech_system
@sub_res = SubRepertoire.where(:id => params[:sub_res]).present? ? SubRepertoire.where(:id => params[:sub_res]).first : "0"
@res = Repertoire.where(:id => params[:res]).first
respond_to do |format|
format.js
end
end
def update_tech_system
if params[:sub_tech] == "0"
Repertoire.where(:id => params[:res]).update_all(:name => params[:update_res])
else
Repertoire.where(:id => params[:res]).update_all(:name => params[:update_res])
SubRepertoire.where(:id => params[:sub_res]).update_all(:name => params[:update_sub_res])
end
redirect_to tech_system_managements_path
end
def setting_banner
@images = PortalImage.order("position asc")
respond_to do |format|
format.js
format.html
end
end
def create_portal_image
PortalImage.create(:name => params[:name], :position => params[:position], :link => params[:link])
redirect_to setting_banner_managements_path
end
def create_school_image
@school = School.find params[:school_id]
SchoolImage.create(:name => params[:name], :position => params[:position], :link => params[:link], :school_id => params[:school_id])
end
def update_school_image
image = SchoolImage.find params[:id]
image.update_attributes(:name => params[:name], :position => params[:position], :link => params[:link])
@school = image.school
end
def up_or_down_image
image = PortalImage.find params[:id]
image.update_attribute(:status, params[:status])
redirect_to setting_banner_managements_path
end
def up_or_down_school_image
image = SchoolImage.find params[:id]
image.update_attribute(:status, params[:status])
@school = image.school
end
def update_portal_image
image = PortalImage.find params[:id]
image.update_attributes(:name => params[:name], :position => params[:position], :link => params[:link])
redirect_to setting_banner_managements_path
end
def delete_portal_image
image = PortalImage.find params[:id]
image.destroy
redirect_to setting_banner_managements_path
end
def delete_school_image
image = SchoolImage.find params[:id]
@school = image.school
image.destroy
end
# 课程删除
before_filter :find_courselist, :only => [:destroy]
# 课程列表的删除
def destroy
if @courselist
CourseList.where(:id => @courselist.id).destroy_all
respond_to do |format|
format.js
end
end
end
private
# Find courselist of id params[:id]
def find_courselist
@courselist = CourseList.find_by_id(params[:id])
render_404 if @courselist.nil?
rescue ActiveRecord::RecordNotFound
render_404
end
def shixun_list_xls shixuns
xls_report = StringIO.new
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet :name => "sheet"
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
sheet1.row(0).default_format = blue
sheet1.row(0).concat(["实训ID","实训名称","技术平台", "Fork源", "实践任务","选择题任务","挑战人数", "通关人数", "状态","创建者", "单位", "职业", "关卡序号","关卡名称","技能标签"])
count_row = 1
shixuns.find_each do |shixun|
sheet1[count_row, 0] = shixun.identifier
sheet1[count_row, 1] = shixun.name
sheet1[count_row, 2] = shixun.shixun_main_name
sheet1[count_row, 3] = shixun.fork_identifier
sheet1[count_row, 4] = shixun.challenges.practice_type.count
sheet1[count_row, 5] = shixun.challenges.choose_type.count
sheet1[count_row, 6] = shixun.myshixuns.count
sheet1[count_row, 7] = shixun.myshixuns.finished.count
sheet1[count_row, 8] = shixun.shixun_status
sheet1[count_row, 9] = shixun.owner.show_real_name
sheet1[count_row, 10] = shixun.owner.school_name
sheet1[count_row, 11] = shixun.owner.identity
shixun.challenges.each do |challenge|
sheet1[count_row, 12] = "#{challenge.position}"
sheet1[count_row, 13] = challenge.subject
sheet1[count_row, 14] = challenge.tags_show
count_row += 1
end
count_row += 1
end
book.write xls_report
xls_report.string
end
def publish_shixun_list shixuns
xls_report = StringIO.new
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet :name => "sheet"
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
sheet1.row(0).default_format = blue
sheet1.row(0).concat(["序号","创建者","发布时间", "ID", "实训名称","技术平台","fork源", "实践任务"])
count_row = 1
shixuns.find_each do |shixun|
sheet1[count_row, 0] = count_row
sheet1[count_row, 1] = shixun.owner.try(:show_real_name)
sheet1[count_row, 2] = format_time shixun.publish_time
sheet1[count_row, 3] = shixun.identifier
sheet1[count_row, 4] = shixun.name
sheet1[count_row, 5] = show_shixun_mirror(shixun)
sheet1[count_row, 6] = shixun.fork_identifier
sheet1[count_row, 7] = shixun.challenges.count
count_row += 1
end
book.write xls_report
xls_report.string
end
def training_2018_xls trainings
xls_report = StringIO.new
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet :name => "sheet"
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
sheet1.row(0).default_format = blue
sheet1.row(0).concat(["姓名", "手机号","邮箱","单位名称", "职位","专业", "学号", "支付方式","支付状态","支付时间", "发票类型", "发票抬头","税务登记号", "发票内容", "备注", "微信支付单号", "报名时间"])
count_row = 1
trainings.find_each do |t|
sheet1[count_row, 0] = t.name
sheet1[count_row, 1] = t.phone
sheet1[count_row, 2] = t.email
sheet1[count_row, 3] = t.school
sheet1[count_row, 4] = t.position
sheet1[count_row, 5] = t.major
sheet1[count_row, 6] = t.student_id
sheet1[count_row, 7] = t.training_payinfo.try(:pay_type_str)
sheet1[count_row, 8] = t.training_payinfo.try(:pay_status_str)
sheet1[count_row, 9] = format_time t.training_payinfo.try(:pay_time)
sheet1[count_row, 10] = t.training_payinfo.try(:invoice_title).present? ? '需要' : '不需要'
sheet1[count_row, 11] = t.training_payinfo.try(:invoice_title)
sheet1[count_row, 12] = t.training_payinfo.try(:invoice_no)
sheet1[count_row, 13] = t.training_payinfo.try(:invoice_content)
sheet1[count_row, 14] = t.training_payinfo.try(:info)
sheet1[count_row, 15] = t.training_payinfo.try(:out_trade_no)
sheet1[count_row, 16] = format_time t.created_at
count_row += 1
end
book.write xls_report
xls_report.string
end
def user_list_xls users
xls_report = StringIO.new
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet :name => "users"
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
sheet1.row(0).default_format = blue
sheet1.row(0).concat(["用户姓名","性别","职业","职称","地区"," 单位","子单位","注册时间","最后登录时间","授权"])
count_row = 1
users.find_each do |user|
sheet1[count_row,0] = user.try(:show_real_name)
sheet1[count_row,1] = user.sex
sheet1[count_row,2] = user.user_extensions.try(:show_identity)
sheet1[count_row,3] = user.job_title
sheet1[count_row,4] = user.region_name
sheet1[count_row,5] = user.user_extensions.try(:school).try(:name)
sheet1[count_row,6] = user.user_extensions.try(:department).try(:name)
sheet1[count_row,7] = format_time user.created_on
sheet1[count_row,8] = format_time user.last_login_on
sheet1[count_row,9] = user.trial_authorization
count_row += 1
end
book.write xls_report
xls_report.string
end
def course_list_xls courses
xls_report = StringIO.new
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet :name => "course"
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
sheet1.row(0).default_format = blue
sheet1.row(0).concat(["ID","课堂名称","成员","资源","普通作业"," 实训作业","试卷","私有","状态","创建者单位","创建者","动态时间"])
count_row = 1
courses.each do |course|
school = course.teacher.try(:user_extensions).try(:school).try(:name).blank? ? "--" : course.teacher.school_name
teacher_name = course.teacher ? course.teacher.show_real_name : ""
sheet1[count_row,0] = course.id
sheet1[count_row,1] = course.name
sheet1[count_row,2] = course.members.count
sheet1[count_row,3] = course.attachments.count
sheet1[count_row,4] = course.homework_commons.where(:homework_type => 1).count
sheet1[count_row,5] = course.homework_commons.where(:homework_type => 4).count
sheet1[count_row,6] = course.exercises.count
sheet1[count_row,7] = course.is_public.to_i == 1 ? '否' : '是'
sheet1[count_row,8] = course.is_end ? "已结束" : "正在进行"
sheet1[count_row,9] = school
sheet1[count_row,10] = teacher_name
sheet1[count_row,11] = format_time(course.updatetime)
count_row += 1
end
book.write xls_report
xls_report.string
end
def shixun_task_xls shixun_task
xls_report = StringIO.new
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet :name => "course"
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
sheet1.row(0).default_format = blue
sheet1.row(0).concat(["ID","课堂名称","创建者","学生","实训作业","序号", "ID", "关卡数","作业名称","发布时间","截至时间","已提交作品","有效作品","通关","状态"])
count_row = 1
shixun_task.each_with_index do |shixun_task,index|
teacher_name = shixun_task.teacher ? shixun_task.teacher.show_real_name : ""
sheet1[count_row,0] = shixun_task.id
sheet1[count_row,1] = shixun_task.name
sheet1[count_row,2] = teacher_name
sheet1[count_row,3] = shixun_task.student.count
sheet1[count_row,4] = get_shixun_task(shixun_task.id).count
get_shixun_task(shixun_task.id).each_with_index do |gst, j|
sheet1[count_row,5] = get_hw_index(gst, @is_teacher, 4) + 1
sheet1[count_row,6] = gst.shixun.try(:identifier).nil? ? "--" : gst.shixun.try(:identifier)
sheet1[count_row,7] = gst.shixun.challenges.count
sheet1[count_row,8] = gst.name
sheet1[count_row,9] = format_time(gst.publish_time)
sheet1[count_row,10] = format_time(gst.end_time)
sheet1[count_row,11] = had_commit_studentwork_count(gst)
sheet1[count_row,12] = effective_shixun_work_count gst
sheet1[count_row,13] = tongguan_shixun_work_count gst
sheet1[count_row,14] = if HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 0
"未发布"
elsif HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 1
"提交中"
elsif HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 3
"匿评中"
elsif HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 4
"申诉中"
elsif HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 5
"评阅中"
else HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 6
"已结束"
end
count_row += 1
end
end
book.write xls_report
xls_report.string
end
def readXlsData(xlsx)
doc = SimpleXlsxReader.open(xlsx)
sheet = doc.sheets.first
return sheet.rows
end
def competition_member_xls members, competition
xls_report = StringIO.new
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet :name => "报名列表"
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
sheet1.row(0).default_format = blue
count_row = 1
records = competition.competition_teams
if competition.identifier == "gcc-annotation-2018"
records.each do |team|
team[:s_score] = team.competition_scores.where(:competition_id => competition.id).first.try(:score).to_f.try(:round, 3)
end
records = records.sort do |a, b|
[b[:s_score]] <=> [a[:s_score]]
end
elsif competition.identifier == "gcc-dev-2018"
pre_stage = competition.competition_stages.where(:name => "预赛").first
final_stage = competition.competition_stages.where(:name => "决赛").first
records.each do |team|
# 决赛记录
f_score = team.competition_scores.where(:competition_stage_id => final_stage.try(:id)).first
# 预赛记录
p_score = team.competition_scores.where(:competition_stage_id => pre_stage.try(:id)).first
team[:s_score] = (f_score.try(:score).to_f * 0.85 + p_score.try(:score).to_f * 0.15).try(:round, 2)
team[:s_spend_time] = f_score.try(:cost_time).to_i + p_score.try(:cost_time).to_i
end
records = records.sort do |a, b|
[b[:s_score], a[:s_spend_time]] <=> [a[:s_score], b[:s_spend_time]]
end
elsif competition.identifier == 'hn'
pre_stage = competition.competition_stages.where(:name => "预赛").first
final_stage = competition.competition_stages.where(:name => "决赛").first
records.each do |team|
f_score = team.competition_scores.where(:competition_stage_id => final_stage.try(:id)).first
p_score = team.competition_scores.where(:competition_stage_id => pre_stage.try(:id)).first
team[:s_score] = (f_score.try(:score).to_f * 0.8 + p_score.try(:score).to_f * 0.2).try(:round, 2)
team[:s_spend_time] = f_score.try(:cost_time).to_i + p_score.try(:cost_time).to_i
end
records = records.sort do |a, b|
[b[:s_score], a[:s_spend_time]] <=> [a[:s_score], b[:s_spend_time]]
end
end
if competition.max_num > 1
sheet1.row(0).concat(["序号", "战队ID", "战队名称","指导老师", "队员姓名", "学号", "实名认证", "职业认证", "学校名称", "地区", "报名时间", "排名"])
members.each_with_index do |member, index|
member_user = member.user
sheet1[count_row,0] = index + 1
sheet1[count_row,1] = member.competition_team.try(:id)
sheet1[count_row,2] = member.competition_team.try(:name)
sheet1[count_row,3] = member.competition_team.teacher.try(:show_real_name)
sheet1[count_row,4] = member_user.try(:show_real_name)
sheet1[count_row,5] = member_user.try(:student_id)
sheet1[count_row,6] = member_user.try(:authentication_status)
sheet1[count_row,7] = member_user.try(:professional_status)
sheet1[count_row,8] = member_user.try(:school_name)
sheet1[count_row,9] = member_user.user_extensions.school.try(:province)
sheet1[count_row,10] = format_time member.created_at
sheet1[count_row,11] = records.present? ? (records.map(&:id).index(member.competition_team_id).to_i + 1) : "--"
count_row += 1
end
else
sheet1.row(0).concat(["序号","姓名","学号","实名认证", "职业认证", "学校名称","地区", "报名时间", "排名"])
members.each_with_index do |member, index|
member_user = member.user
sheet1[count_row,0] = index + 1
sheet1[count_row,1] = member_user.try(:show_real_name)
sheet1[count_row,2] = member_user.try(:student_id)
sheet1[count_row,3] = member_user.try(:authentication_status)
sheet1[count_row,4] = member_user.try(:professional_status)
sheet1[count_row,5] = member_user.try(:school_name)
sheet1[count_row,6] = member_user.user_extensions.school.try(:province)
sheet1[count_row,7] = format_time member.created_at
sheet1[count_row,8] = records.present? ? (records.map(&:id).index(member.competition_team_id).to_i + 1) : "--"
count_row += 1
end
end
book.write xls_report
xls_report.string
end
def published_subject_xls subjects
xls_report = StringIO.new
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet :name => "已发布实训课程"
count_row = 2
sheet1.row(1).concat(["", "地址", "实训课程名称","章节名称", "实训组成", "关卡数", "状态", "更新时间"])
Rails.logger.warn("##########subjects:#{subjects.count}")
subjects.each do |subject|
sheet1[count_row,1] = "paths/"+subject.id.to_s
sheet1[count_row,2] = subject.name
if subject.stages.count > 0
subject.stages.each_with_index do |stage, s_index|
sheet1[count_row,3] = stage.name
if stage.shixuns.count > 0
stage.shixuns.each_with_index do |shixun, index|
sheet1[count_row,4] = "#{s_index + 1}-#{index + 1} #{shixun.name}"
sheet1[count_row,5] = shixun.challenges.count
sheet1[count_row,6] = shixun.shixun_status
if s_index == 0 && index == 0
sheet1[count_row,7] = format_time subject.updated_at
end
count_row += 1
end
else
if s_index == 0
sheet1[count_row,7] = format_time subject.updated_at
end
count_row += 1
end
end
else
sheet1[count_row,7] = format_time subject.updated_at
count_row += 1
end
end
book.write xls_report
xls_report.string
end
end