# 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]
if params[:search].to_i.to_s == params[:search].to_s
myshixun_id = Game.where(:myshixun_id => params[:search].to_i).pluck(:myshixun_id)
else
myshixun_id = Game.where(:identifier => params[:search]).pluck(:myshixun_id)
end
@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 更新新ID,1 回退
# old_id: 平台保存的ID
# change_id: 用户修改的新ID
# 选择镜像后,向中间层updateImage flag: 0 更新新ID,1 回退镜像
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 字符类型。eg:shixun_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 = "您所在团队提交的课程实训发布申请:#{subject.name},审核未通过。
原因:#{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