|
|
# encoding: utf-8
|
|
|
class ManagementsController < ApplicationController
|
|
|
before_filter :require_admin
|
|
|
layout 'base_management'
|
|
|
include ManagementsHelper
|
|
|
include SortHelper
|
|
|
include UsersHelper
|
|
|
include ApplicationHelper
|
|
|
include AvatarHelper
|
|
|
include ShixunsHelper
|
|
|
helper :files
|
|
|
if RUBY_PLATFORM =~ /linux/
|
|
|
require 'simple_xlsx_reader'
|
|
|
require 'roo-xls'
|
|
|
end
|
|
|
|
|
|
CODES = %W(2 3 4 5 6 7 8 9 A B C D E F G H J K L N M O P Q R S T U V W X Y Z)
|
|
|
|
|
|
# 工程认证视频导入模板
|
|
|
def ec_template
|
|
|
@template = EcTemplate.where(nil)
|
|
|
|
|
|
end
|
|
|
|
|
|
def add_template
|
|
|
logger.info("#############################{params}")
|
|
|
EcTemplate.create(:name => params[:name].strip)
|
|
|
@template = EcTemplate.where(nil)
|
|
|
end
|
|
|
|
|
|
def training_2018
|
|
|
@search = params[:search]
|
|
|
@training_type = params[:training_type]
|
|
|
@pay_type = params[:pay_type]
|
|
|
@page = params[:page] || 1
|
|
|
@status = params[:status]
|
|
|
if User.current.admin?
|
|
|
@trainings = Training.includes(:training_payinfo)
|
|
|
if params[:search] && params[:search].strip != ""
|
|
|
@trainings = @trainings.where("trainings.name like '%#{params[:search]}%'")
|
|
|
end
|
|
|
if params[:training_type] && params[:training_type].to_i != -1
|
|
|
@trainings = @trainings.where("training_type = #{params[:training_type]}")
|
|
|
end
|
|
|
if params[:pay_type] && params[:pay_type].to_i != -1
|
|
|
@trainings = @trainings.where("training_payinfos.pay_type = #{params[:pay_type]}")
|
|
|
end
|
|
|
if params[:status] && params[:status].to_i != -1
|
|
|
@trainings = @trainings.where("training_payinfos.status = #{params[:status]}")
|
|
|
end
|
|
|
@page = params[:page] || 1
|
|
|
@all_trainings = @trainings.reorder("trainings.created_at desc")
|
|
|
@trainings = paginateHelper @trainings.reorder("trainings.created_at desc"), 50
|
|
|
else
|
|
|
render_403
|
|
|
end
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
format.html
|
|
|
format.xls{
|
|
|
time = Time.now.strftime("%Y%m%d")
|
|
|
filename = "#{time}培训会报名列表.xls"
|
|
|
send_data(training_2018_xls(@all_trainings), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
|
|
|
}
|
|
|
end
|
|
|
end
|
|
|
|
|
|
def update_pay_status
|
|
|
if User.current.admin? || User.current.id == 1
|
|
|
@training = Training.where(:id => params[:training]).first
|
|
|
if @training
|
|
|
@training.training_payinfo.update_attributes(:status => TrainingPayinfo::Status_Payed)
|
|
|
if @training.phone.present?
|
|
|
Trustie::Sms.send(mobile: @training.phone.to_s, send_type: "training_pay", user_name: @training.name)
|
|
|
end
|
|
|
end
|
|
|
else
|
|
|
render_403
|
|
|
end
|
|
|
end
|
|
|
|
|
|
def mul_test
|
|
|
@menu_type = 3
|
|
|
@sub_type = 9
|
|
|
@m_tests = MulTest.where(nil)
|
|
|
|
|
|
@m_tests_count = @m_tests.count
|
|
|
@m_tests_pages = Paginator.new @m_tests_count, 20, params['page'] || 1
|
|
|
@offset ||= @m_tests_pages.offset
|
|
|
@m_tests = paginateHelper @m_tests, 20
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
format.html
|
|
|
end
|
|
|
end
|
|
|
|
|
|
def mul_statics
|
|
|
@m_tests = MulTest.all.group_by{|o|[o.num, o.shixun_id]}
|
|
|
# @m_tests_count = @m_tests.count
|
|
|
# @m_tests_pages = Paginator.new @m_tests_count, 20, params['page'] || 1
|
|
|
# @offset ||= @m_tests_pages.offset
|
|
|
# @m_tests = paginateHelper @m_tests, 20
|
|
|
end
|
|
|
|
|
|
def update_shixun_usescope
|
|
|
shixun = Shixun.where(:id => params[:shixun_id]).first
|
|
|
shixun.update_column(:use_scope, params[:use_scope].to_i)
|
|
|
render :json => {status: "success"}
|
|
|
end
|
|
|
|
|
|
#用户修改
|
|
|
def myshixuns
|
|
|
@menu_type = 3
|
|
|
@sub_type = 8
|
|
|
@g = Gitlab.client
|
|
|
if params[:search]
|
|
|
myshixun_id = Game.where(:identifier => params[:search]).pluck(:myshixun_id)
|
|
|
@myshixuns = Myshixun.where(:id => myshixun_id).includes(:shixun)
|
|
|
else
|
|
|
@myshixuns = Myshixun.where("0=0").includes(:shixun)
|
|
|
end
|
|
|
@myshixuns_count = @myshixuns.count
|
|
|
limit = 20
|
|
|
@myshixuns_pages = Paginator.new @myshixuns_count, limit, params['page'] || 1
|
|
|
@offset ||= @myshixuns_pages.offset
|
|
|
@myshixuns = paginateHelper @myshixuns, limit
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
format.html
|
|
|
end
|
|
|
end
|
|
|
|
|
|
def myshixun_info
|
|
|
user_id = User.where(:login => params[:login].strip).pluck(:id).first
|
|
|
shixun_id = Shixun.where(:identifier => params[:shixun_id].strip).pluck(:id).first
|
|
|
myshixun = Myshixun.where(:user_id => user_id, :shixun_id => shixun_id).first
|
|
|
game = myshixun.current_task
|
|
|
@game_url = Setting.protocol + "://" + Setting.host_name + "/tasks/#{game.identifier}"
|
|
|
@git_url = Redmine::Configuration['gitlab_address']+"/"+myshixun.git_url
|
|
|
end
|
|
|
|
|
|
def anomaly_detection
|
|
|
|
|
|
end
|
|
|
|
|
|
def account
|
|
|
@user = User.find(params[:user_id])
|
|
|
begin
|
|
|
if request.post?
|
|
|
@user.nickname = params[:nickname]
|
|
|
@user.lastname = params[:lastname]
|
|
|
@user.firstname = ""
|
|
|
@user.mail = params[:mail].strip == "" ? nil : params[:mail]
|
|
|
@user.phone = params[:phone].strip == "" ? nil : params[:phone]
|
|
|
#@user.password = params[:new_password]
|
|
|
# if params[:new_password].strip != "" && params[:new_password_confirmation].strip != ""
|
|
|
# @user.password, @user.password_confirmation = params[:new_password], params[:new_password_confirmation]
|
|
|
# end
|
|
|
@se = @user.extensions
|
|
|
@se.school_id = params[:occupation]
|
|
|
@se.department_id = params[:department_id]
|
|
|
@se.gender = params[:sex]
|
|
|
@se.location = params[:province] if params[:province]
|
|
|
@se.location_city = params[:city] if params[:city]
|
|
|
@se.identity = params[:identity].to_i if params[:identity]
|
|
|
if @se.identity == 0
|
|
|
@se.technical_title = params[:te_technical_title] if params[:te_technical_title]
|
|
|
@se.student_id = nil
|
|
|
elsif @se.identity == 1
|
|
|
@se.student_id = params[:no] if params[:no]
|
|
|
@se.technical_title = nil
|
|
|
elsif @se.identity == 2
|
|
|
@se.technical_title = params[:pro_technical_title] if params[:pro_technical_title]
|
|
|
@se.student_id = nil
|
|
|
end
|
|
|
@se.brief_introduction = params[:brief_introduction]
|
|
|
@user.save
|
|
|
@se.save
|
|
|
us = UsersService.new
|
|
|
@user = us.change_password params.merge(:current_user_id => @user.id)
|
|
|
# if @user.save && @se.save
|
|
|
# reward_grade(@user, @user.id, 'Account', 500)
|
|
|
# # 头像保存
|
|
|
# FileUtils.mv diskfile1, diskfile, force: true if File.exist? diskfile1
|
|
|
# @user.pref.save
|
|
|
# @user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
|
|
|
# set_language_if_valid @user.language
|
|
|
# flash[:notice] = l(:notice_account_updated)
|
|
|
# return
|
|
|
# else
|
|
|
# # @user.login = lg
|
|
|
# end
|
|
|
|
|
|
end
|
|
|
# 不管前面是否有异常,如果文件已存在就删除
|
|
|
ensure
|
|
|
end
|
|
|
# @setting_type = 1
|
|
|
|
|
|
redirect_to update_user_managements_path(:user => @user)
|
|
|
end
|
|
|
|
|
|
# 获取镜像
|
|
|
def pull_mirror
|
|
|
#params[:jsonMirrorDetails] = '{"images":[{"imageID":"2367ee7a7d4c","name":"octave-novnc:v1.0"}, {"imageID":"1b9cfba2c4dd","name":"jfinal-mysql55:v1.0"}]}'
|
|
|
ActiveRecord::Base.transaction do
|
|
|
begin
|
|
|
shixun_tomcat = Redmine::Configuration['shixun_tomcat']
|
|
|
params = {}
|
|
|
uri = "#{shixun_tomcat}/bridge/docker/images"
|
|
|
res = uri_exec uri, params
|
|
|
if (res && res['code'] != 0)
|
|
|
raise("Pull mirror the repository exception")
|
|
|
end
|
|
|
mirrors = res["images"]
|
|
|
images = [] # 中间层镜像名称的数组
|
|
|
if mirrors.present?
|
|
|
mirrors.each do |mirror|
|
|
|
mirror = JSON.parse(mirror)
|
|
|
match_rep_mirror_name = MirrorRepository.where(:name => mirror['imageName']).first
|
|
|
match_rep_mirror_id = MirrorRepository.where(:mirrorID => mirror['imageID']).first
|
|
|
images << mirror['imageName']
|
|
|
if match_rep_mirror_name.blank? && match_rep_mirror_id.blank?
|
|
|
# 镜像不存在、创建镜像
|
|
|
new_mirror = MirrorRepository.create!(:mirrorID => mirror['imageID'], :name => mirror['imageName'])
|
|
|
MirrorOperationRecord.create!(:mirror_repository_id => new_mirror.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 0, :user_id => -1)
|
|
|
elsif match_rep_mirror_name.present? && match_rep_mirror_id.blank?
|
|
|
# 镜像ID被修改
|
|
|
match_rep_mirror_name.update_attributes(:status => 2)
|
|
|
MirrorOperationRecord.create!(:mirror_repository_id => match_rep_mirror_name.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 1, :user_id => -1)
|
|
|
elsif match_rep_mirror_name.blank? && match_rep_mirror_id.present?
|
|
|
# 镜像名称被修改
|
|
|
match_rep_mirror_id.update_attribute(:status, 3)
|
|
|
MirrorOperationRecord.create!(:mirror_repository_id => match_rep_mirror_id.id, :mirror_id => mirror['imageID'], :mirror_name => mirror['imageName'], :status => 2, :user_id => -1)
|
|
|
end
|
|
|
end
|
|
|
end
|
|
|
# 判断中间层镜像是否被删除
|
|
|
edu_mirrors = MirrorRepository.all
|
|
|
edu_mirrors.each do |mirror|
|
|
|
if(images.index(mirror.try(:name)).nil? && mirror.try(:name).present?)
|
|
|
mirror.update_attribute(:status, 4)
|
|
|
MirrorOperationRecord.create!(:mirror_repository_id => mirror.id, :mirror_id => mirror.try(:mirrorID), :mirror_name => mirror.name, :status => 3, :user_id => -1)
|
|
|
end
|
|
|
end
|
|
|
# end
|
|
|
redirect_to mirror_repository_managements_path
|
|
|
rescue Exception => e
|
|
|
logger.error("pull_mirror error: #{e}")
|
|
|
raise ActiveRecord::Rollback
|
|
|
end
|
|
|
end
|
|
|
end
|
|
|
|
|
|
# 验证镜像名是否重复
|
|
|
# 判断依据:主类别和小类别可以同名;主类别和小类别各自之间
|
|
|
def check_mirror_name
|
|
|
random = CODES.sample(8).join
|
|
|
mirror_count = MirrorRepository.where("type_name = ? and id != ? and main_type =?", params[:type_name], params[:mirror_id], params[:main_type].to_i).count
|
|
|
check = (mirror_count > 0 ? true : false)
|
|
|
render :json => {check: check, random: random}
|
|
|
end
|
|
|
|
|
|
# 中间层与edu镜像不一致时,选择镜像一个可用的版本
|
|
|
def choose_mirror
|
|
|
@mirror = MirrorRepository.find(params[:mirror_id])
|
|
|
@new_mirror = MirrorOperationRecord.where(:mirror_repository_id => @mirror.id, :status => 1, :user_id => -1).first
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
end
|
|
|
end
|
|
|
|
|
|
# flag: 0 更新新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 = "您所在团队提交的课程实训发布申请:<a href='#{subject_path(subject)}'>#{subject.name}</a>,审核未通过。<br/>原因:#{params[:reject_reason]}"
|
|
|
# JournalsForMessage.create(:jour_id => subject.user_id, :jour_type => 'Principal', :user_id => User.current.id, :notes => notes, :private => 1, :reply_id => 0)
|
|
|
=begin
|
|
|
begin
|
|
|
# verification_code = code.sample(6).join
|
|
|
if subject.owner.phone.present?
|
|
|
status = Trustie::Sms.send(mobile: subject.owner.phone.to_s, code: '1', send_type:'subject_authorization', name:subject.name, user_name:subject.owner.show_name, result:'未通过')
|
|
|
end
|
|
|
rescue => e
|
|
|
Rails.logger.error "发送验证码出错: #{e}"
|
|
|
end
|
|
|
=end
|
|
|
|
|
|
else #同意
|
|
|
subject.update_attributes(:status =>2, :publish_time => Time.now)
|
|
|
apply_action.update_attributes(:status => 1, :dealer_id => User.current.id)
|
|
|
=begin
|
|
|
begin
|
|
|
unless subject.owner.phone.present?
|
|
|
status = Trustie::Sms.send(mobile: subject.owner.phone.to_s, code: '1', send_type:'subject_authorization', name:subject.name, user_name:subject.owner.show_name, result:'已通过')
|
|
|
end
|
|
|
rescue => e
|
|
|
Rails.logger.error "发送验证码出错: #{e}"
|
|
|
end
|
|
|
=end
|
|
|
end
|
|
|
Tiding.where(:user_id => 1 ,:trigger_user_id => apply_action.user_id, :container_id => apply_action.id, :container_type => 'ApplyAction', :tiding_type => "Apply", :status => 0).update_all(:status => 1)
|
|
|
Tiding.create(:user_id => apply_action.user_id, :trigger_user_id => 0, :container_id => apply_action.id, :container_type => 'ApplyAction',
|
|
|
:parent_container_id => apply_action.container_id, :parent_container_type => apply_action.container_type, :belong_container_id => apply_action.container_id, :belong_container_type => "Subject", :tiding_type => "System", :status => type == 0 ? 2 : 1)
|
|
|
|
|
|
@authorizations = ApplyAction.where(:container_type => "ApplySubject", :status => 0)
|
|
|
@authorizations_count = @authorizations.count
|
|
|
@limit = 15
|
|
|
@is_remote = true
|
|
|
@authorizations_pages = Paginator.new @authorizations_count, @limit, params['page'] || 1
|
|
|
@offset ||= @authorizations_pages.offset
|
|
|
@authorizations = paginateHelper @authorizations, @limit
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
end
|
|
|
end
|
|
|
|
|
|
# 项目实训发布审批
|
|
|
def deal_shixun_authorization
|
|
|
apply_action = ApplyAction.find(params[:apply_id])
|
|
|
type = params[:type].to_i
|
|
|
shixun = Shixun.find apply_action.container_id
|
|
|
shixun_creator = shixun.owner
|
|
|
if type == 0 #拒绝
|
|
|
shixun.update_column('status', 0)
|
|
|
apply_action.update_attributes(:status => 2, :reason => params[:reject_reason], :dealer_id => User.current.id)
|
|
|
=begin
|
|
|
begin
|
|
|
if shixun_creator.phone.present?
|
|
|
status = Trustie::Sms.send(mobile: shixun_creator.phone.to_s, code: '1', send_type:'shixun_authorization', name:shixun.name, user_name:shixun_creator.show_name, result:'未通过')
|
|
|
end
|
|
|
rescue => e
|
|
|
Rails.logger.error "发送验证码出错: #{e}"
|
|
|
end
|
|
|
=end
|
|
|
|
|
|
else #同意
|
|
|
# 给实训制作者奖励“金币/经验” (奖励数额:实训关卡的金币的总数)
|
|
|
score = shixun.all_score
|
|
|
grade = Grade.where(:user_id => shixun.user_id, :container_id => shixun.id, :container_type => "shixunPublish").first
|
|
|
if grade.blank? # 防止多条创建
|
|
|
Grade.create(:user_id => shixun.user_id, :container_id => shixun.id, :container_type => "shixunPublish", :score => score)
|
|
|
Experience.create(:user_id => shixun.user_id, :container_id => shixun.id, :container_type => "shixunPublish", :score => score)
|
|
|
shixun_creator.update_attributes(:grade => shixun_creator.grade + score, :experience => shixun_creator.experience + score)
|
|
|
end
|
|
|
|
|
|
shixun.update_column('status', 2)
|
|
|
apply_action.update_attributes(:status => 1, :dealer_id => User.current.id)
|
|
|
shixun = Shixun.where(:id => apply_action.container_id).first
|
|
|
shixun.update_attribute(:publish_time, Time.now)
|
|
|
# 实训通关则给实训制作者相应的金币奖励
|
|
|
|
|
|
shixun_modify_status_without_publish shixun, 1
|
|
|
=begin
|
|
|
begin
|
|
|
if shixun_creator.phone.present?
|
|
|
status = Trustie::Sms.send(mobile: shixun.owner.phone.to_s, code: '1', send_type:'shixun_authorization', name:shixun.name, user_name:shixun.owner.show_name, result:'已通过')
|
|
|
end
|
|
|
rescue => e
|
|
|
Rails.logger.error "发送验证码出错: #{e}"
|
|
|
end
|
|
|
=end
|
|
|
end
|
|
|
Tiding.where(:user_id => 1 ,:trigger_user_id => apply_action.user_id, :container_id => apply_action.id, :container_type => 'ApplyAction', :tiding_type => "Apply", :status => 0).update_all(:status => 1)
|
|
|
Tiding.create(:user_id => apply_action.user_id, :trigger_user_id => 0, :container_id => apply_action.id, :container_type => 'ApplyAction',
|
|
|
:parent_container_id => apply_action.container_id, :parent_container_type => apply_action.container_type, :belong_container_id => apply_action.container_id, :belong_container_type => "Shixun", :tiding_type => "System", :status => type == 0 ? 2 : 1)
|
|
|
|
|
|
|
|
|
@authorizations = ApplyAction.where(:container_type => "ApplyShixun", :status => 0)
|
|
|
@authorizations_count = @authorizations.count
|
|
|
@limit = 15
|
|
|
@is_remote = true
|
|
|
@authorizations_pages = Paginator.new @authorizations_count, @limit, params['page'] || 1
|
|
|
@offset ||= @authorizations_pages.offset
|
|
|
@authorizations = paginateHelper @authorizations, @limit
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
end
|
|
|
end
|
|
|
|
|
|
def tech_system
|
|
|
@menu_type = 12
|
|
|
@sub_type = 5
|
|
|
@tech_system = Repertoire.where(nil).order("updated_at asc")
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
format.html
|
|
|
end
|
|
|
end
|
|
|
|
|
|
# 创建体系
|
|
|
def create_system
|
|
|
rep_name = params[:repertoire]
|
|
|
sub_rep_name = params[:sub_repertoire]
|
|
|
tags_name = params[:tag_repertoire]
|
|
|
ActiveRecord::Base.transaction do
|
|
|
begin
|
|
|
rep = Repertoire.create!(:name => rep_name)
|
|
|
sub_rep = SubRepertoire.create!(:name => sub_rep_name, :repertoire_id => rep.id)
|
|
|
tags_name.each do |tag|
|
|
|
TagRepertoire.create!(:name => tag, :sub_repertoire_id => sub_rep.id)
|
|
|
end
|
|
|
redirect_to tech_system_managements_path
|
|
|
rescue Exception => e
|
|
|
logger.error("create_system error: #{e}")
|
|
|
raise ActiveRecord::Rollback
|
|
|
end
|
|
|
end
|
|
|
end
|
|
|
|
|
|
# 更新tag_repertores的名称
|
|
|
def update_tag_name
|
|
|
tag = TagRepertoire.find(params[:id])
|
|
|
if params[:name].blank?
|
|
|
tag.destroy
|
|
|
else
|
|
|
if tag.name == params[:name].strip
|
|
|
tag.update_column(:updated_at, Time.now)
|
|
|
else
|
|
|
tag.update_attribute(:name, params[:name])
|
|
|
end
|
|
|
end
|
|
|
render :json => {success: "true"}
|
|
|
end
|
|
|
|
|
|
# 更新sub_repertores的名称
|
|
|
def update_sub_name
|
|
|
sub = SubRepertoire.find(params[:id])
|
|
|
if params[:name].blank?
|
|
|
sub.destroy
|
|
|
else
|
|
|
if sub.name == params[:name].strip
|
|
|
sub.update_column(:updated_at, Time.now)
|
|
|
else
|
|
|
sub.update_attribute(:name, params[:name])
|
|
|
end
|
|
|
end
|
|
|
render :json => {success: "true"}
|
|
|
end
|
|
|
|
|
|
def update_rep_name
|
|
|
rep = Repertoire.find(params[:id])
|
|
|
if params[:name].blank?
|
|
|
rep.destroy
|
|
|
else
|
|
|
if rep.name == params[:name].strip
|
|
|
rep.update_column(:updated_at, Time.now)
|
|
|
else
|
|
|
rep.update_attribute(:name, params[:name])
|
|
|
end
|
|
|
end
|
|
|
render :json => {success: "true"}
|
|
|
end
|
|
|
|
|
|
# type: 1表示新建sub_repertoire, 2表示新建tag_repertoire
|
|
|
def create_sub_or_tag_repertoire
|
|
|
type = params[:type].to_i
|
|
|
if type == 1
|
|
|
SubRepertoire.create(:name => params[:name], :repertoire_id => params[:id])
|
|
|
elsif type == 2
|
|
|
TagRepertoire.create(:name =>params[:name], :sub_repertoire_id => params[:id])
|
|
|
end
|
|
|
respond_to do |format|
|
|
|
format.js{redirect_to tech_system_managements_path}
|
|
|
end
|
|
|
end
|
|
|
|
|
|
def delete_sub_tech_system
|
|
|
sub_tech = SubRepertoire.where(:id => params[:sub_res]).first
|
|
|
tech = Repertoire.where(:id => params[:sub_res]).first
|
|
|
if sub_tech.present?
|
|
|
sub_tech.destroy
|
|
|
else
|
|
|
tech.destroy
|
|
|
end
|
|
|
redirect_to tech_system_managements_path
|
|
|
end
|
|
|
|
|
|
def create_tech_system
|
|
|
if params[:index] == "1"
|
|
|
Repertoire.create(:name => params[:res_tech])
|
|
|
else
|
|
|
SubRepertoire.create(:name => params[:sub_tech], :repertoire_id => params[:tech])
|
|
|
end
|
|
|
redirect_to tech_system_managements_path
|
|
|
end
|
|
|
|
|
|
def rename_tech_system
|
|
|
@sub_res = SubRepertoire.where(:id => params[:sub_res]).present? ? SubRepertoire.where(:id => params[:sub_res]).first : "0"
|
|
|
@res = Repertoire.where(:id => params[:res]).first
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
end
|
|
|
end
|
|
|
|
|
|
def update_tech_system
|
|
|
if params[:sub_tech] == "0"
|
|
|
Repertoire.where(:id => params[:res]).update_all(:name => params[:update_res])
|
|
|
else
|
|
|
Repertoire.where(:id => params[:res]).update_all(:name => params[:update_res])
|
|
|
SubRepertoire.where(:id => params[:sub_res]).update_all(:name => params[:update_sub_res])
|
|
|
end
|
|
|
redirect_to tech_system_managements_path
|
|
|
end
|
|
|
|
|
|
def setting_banner
|
|
|
@images = PortalImage.order("position asc")
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
format.html
|
|
|
end
|
|
|
end
|
|
|
|
|
|
def create_portal_image
|
|
|
PortalImage.create(:name => params[:name], :position => params[:position], :link => params[:link])
|
|
|
redirect_to setting_banner_managements_path
|
|
|
end
|
|
|
|
|
|
def create_school_image
|
|
|
@school = School.find params[:school_id]
|
|
|
SchoolImage.create(:name => params[:name], :position => params[:position], :link => params[:link], :school_id => params[:school_id])
|
|
|
end
|
|
|
|
|
|
def update_school_image
|
|
|
image = SchoolImage.find params[:id]
|
|
|
image.update_attributes(:name => params[:name], :position => params[:position], :link => params[:link])
|
|
|
@school = image.school
|
|
|
end
|
|
|
|
|
|
def up_or_down_image
|
|
|
image = PortalImage.find params[:id]
|
|
|
image.update_attribute(:status, params[:status])
|
|
|
redirect_to setting_banner_managements_path
|
|
|
end
|
|
|
|
|
|
def up_or_down_school_image
|
|
|
image = SchoolImage.find params[:id]
|
|
|
image.update_attribute(:status, params[:status])
|
|
|
@school = image.school
|
|
|
end
|
|
|
|
|
|
|
|
|
def update_portal_image
|
|
|
image = PortalImage.find params[:id]
|
|
|
image.update_attributes(:name => params[:name], :position => params[:position], :link => params[:link])
|
|
|
redirect_to setting_banner_managements_path
|
|
|
end
|
|
|
|
|
|
def delete_portal_image
|
|
|
image = PortalImage.find params[:id]
|
|
|
image.destroy
|
|
|
redirect_to setting_banner_managements_path
|
|
|
end
|
|
|
|
|
|
def delete_school_image
|
|
|
image = SchoolImage.find params[:id]
|
|
|
@school = image.school
|
|
|
image.destroy
|
|
|
end
|
|
|
|
|
|
# 课程删除
|
|
|
before_filter :find_courselist, :only => [:destroy]
|
|
|
|
|
|
# 课程列表的删除
|
|
|
def destroy
|
|
|
if @courselist
|
|
|
CourseList.where(:id => @courselist.id).destroy_all
|
|
|
respond_to do |format|
|
|
|
format.js
|
|
|
end
|
|
|
end
|
|
|
end
|
|
|
private
|
|
|
# Find courselist of id params[:id]
|
|
|
def find_courselist
|
|
|
@courselist = CourseList.find_by_id(params[:id])
|
|
|
render_404 if @courselist.nil?
|
|
|
rescue ActiveRecord::RecordNotFound
|
|
|
render_404
|
|
|
end
|
|
|
|
|
|
def shixun_list_xls shixuns
|
|
|
xls_report = StringIO.new
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
sheet1 = book.create_worksheet :name => "sheet"
|
|
|
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
|
|
sheet1.row(0).default_format = blue
|
|
|
sheet1.row(0).concat(["实训ID","实训名称","技术平台", "Fork源", "实践任务","选择题任务","挑战人数", "通关人数", "状态","创建者", "单位", "职业", "关卡序号","关卡名称","技能标签"])
|
|
|
count_row = 1
|
|
|
shixuns.find_each do |shixun|
|
|
|
sheet1[count_row, 0] = shixun.identifier
|
|
|
sheet1[count_row, 1] = shixun.name
|
|
|
sheet1[count_row, 2] = shixun.shixun_main_name
|
|
|
sheet1[count_row, 3] = shixun.fork_identifier
|
|
|
sheet1[count_row, 4] = shixun.challenges.practice_type.count
|
|
|
sheet1[count_row, 5] = shixun.challenges.choose_type.count
|
|
|
sheet1[count_row, 6] = shixun.myshixuns.count
|
|
|
sheet1[count_row, 7] = shixun.myshixuns.finished.count
|
|
|
sheet1[count_row, 8] = shixun.shixun_status
|
|
|
sheet1[count_row, 9] = shixun.owner.show_real_name
|
|
|
sheet1[count_row, 10] = shixun.owner.school_name
|
|
|
sheet1[count_row, 11] = shixun.owner.identity
|
|
|
shixun.challenges.each do |challenge|
|
|
|
sheet1[count_row, 12] = "第#{challenge.position}关"
|
|
|
sheet1[count_row, 13] = challenge.subject
|
|
|
sheet1[count_row, 14] = challenge.tags_show
|
|
|
count_row += 1
|
|
|
end
|
|
|
count_row += 1
|
|
|
end
|
|
|
book.write xls_report
|
|
|
xls_report.string
|
|
|
end
|
|
|
|
|
|
def publish_shixun_list shixuns
|
|
|
xls_report = StringIO.new
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
sheet1 = book.create_worksheet :name => "sheet"
|
|
|
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
|
|
sheet1.row(0).default_format = blue
|
|
|
sheet1.row(0).concat(["序号","创建者","发布时间", "ID", "实训名称","技术平台","fork源", "实践任务"])
|
|
|
count_row = 1
|
|
|
shixuns.find_each do |shixun|
|
|
|
sheet1[count_row, 0] = count_row
|
|
|
sheet1[count_row, 1] = shixun.owner.try(:show_real_name)
|
|
|
sheet1[count_row, 2] = format_time shixun.publish_time
|
|
|
sheet1[count_row, 3] = shixun.identifier
|
|
|
sheet1[count_row, 4] = shixun.name
|
|
|
sheet1[count_row, 5] = show_shixun_mirror(shixun)
|
|
|
sheet1[count_row, 6] = shixun.fork_identifier
|
|
|
sheet1[count_row, 7] = shixun.challenges.count
|
|
|
count_row += 1
|
|
|
end
|
|
|
book.write xls_report
|
|
|
xls_report.string
|
|
|
end
|
|
|
|
|
|
def training_2018_xls trainings
|
|
|
xls_report = StringIO.new
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
sheet1 = book.create_worksheet :name => "sheet"
|
|
|
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
|
|
sheet1.row(0).default_format = blue
|
|
|
sheet1.row(0).concat(["姓名", "手机号","邮箱","单位名称", "职位","专业", "学号", "支付方式","支付状态","支付时间", "发票类型", "发票抬头","税务登记号", "发票内容", "备注", "微信支付单号", "报名时间"])
|
|
|
count_row = 1
|
|
|
trainings.find_each do |t|
|
|
|
sheet1[count_row, 0] = t.name
|
|
|
sheet1[count_row, 1] = t.phone
|
|
|
sheet1[count_row, 2] = t.email
|
|
|
sheet1[count_row, 3] = t.school
|
|
|
sheet1[count_row, 4] = t.position
|
|
|
sheet1[count_row, 5] = t.major
|
|
|
sheet1[count_row, 6] = t.student_id
|
|
|
sheet1[count_row, 7] = t.training_payinfo.try(:pay_type_str)
|
|
|
sheet1[count_row, 8] = t.training_payinfo.try(:pay_status_str)
|
|
|
sheet1[count_row, 9] = format_time t.training_payinfo.try(:pay_time)
|
|
|
sheet1[count_row, 10] = t.training_payinfo.try(:invoice_title).present? ? '需要' : '不需要'
|
|
|
sheet1[count_row, 11] = t.training_payinfo.try(:invoice_title)
|
|
|
sheet1[count_row, 12] = t.training_payinfo.try(:invoice_no)
|
|
|
sheet1[count_row, 13] = t.training_payinfo.try(:invoice_content)
|
|
|
sheet1[count_row, 14] = t.training_payinfo.try(:info)
|
|
|
sheet1[count_row, 15] = t.training_payinfo.try(:out_trade_no)
|
|
|
sheet1[count_row, 16] = format_time t.created_at
|
|
|
count_row += 1
|
|
|
end
|
|
|
book.write xls_report
|
|
|
xls_report.string
|
|
|
end
|
|
|
|
|
|
def user_list_xls users
|
|
|
xls_report = StringIO.new
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
sheet1 = book.create_worksheet :name => "users"
|
|
|
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
|
|
sheet1.row(0).default_format = blue
|
|
|
sheet1.row(0).concat(["用户姓名","性别","职业","职称","地区"," 单位","子单位","注册时间","最后登录时间","授权"])
|
|
|
count_row = 1
|
|
|
users.find_each do |user|
|
|
|
sheet1[count_row,0] = user.try(:show_real_name)
|
|
|
sheet1[count_row,1] = user.sex
|
|
|
sheet1[count_row,2] = user.user_extensions.try(:show_identity)
|
|
|
sheet1[count_row,3] = user.job_title
|
|
|
sheet1[count_row,4] = user.region_name
|
|
|
sheet1[count_row,5] = user.user_extensions.try(:school).try(:name)
|
|
|
sheet1[count_row,6] = user.user_extensions.try(:department).try(:name)
|
|
|
sheet1[count_row,7] = format_time user.created_on
|
|
|
sheet1[count_row,8] = format_time user.last_login_on
|
|
|
sheet1[count_row,9] = user.trial_authorization
|
|
|
count_row += 1
|
|
|
end
|
|
|
book.write xls_report
|
|
|
xls_report.string
|
|
|
end
|
|
|
|
|
|
def course_list_xls courses
|
|
|
xls_report = StringIO.new
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
sheet1 = book.create_worksheet :name => "course"
|
|
|
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
|
|
sheet1.row(0).default_format = blue
|
|
|
sheet1.row(0).concat(["ID","课堂名称","成员","资源","普通作业"," 实训作业","试卷","私有","状态","创建者单位","创建者","动态时间"])
|
|
|
count_row = 1
|
|
|
courses.each do |course|
|
|
|
school = course.teacher.try(:user_extensions).try(:school).try(:name).blank? ? "--" : course.teacher.school_name
|
|
|
teacher_name = course.teacher ? course.teacher.show_real_name : ""
|
|
|
sheet1[count_row,0] = course.id
|
|
|
sheet1[count_row,1] = course.name
|
|
|
sheet1[count_row,2] = course.members.count
|
|
|
sheet1[count_row,3] = course.attachments.count
|
|
|
sheet1[count_row,4] = course.homework_commons.where(:homework_type => 1).count
|
|
|
sheet1[count_row,5] = course.homework_commons.where(:homework_type => 4).count
|
|
|
sheet1[count_row,6] = course.exercises.count
|
|
|
sheet1[count_row,7] = course.is_public.to_i == 1 ? '否' : '是'
|
|
|
sheet1[count_row,8] = course.is_end ? "已结束" : "正在进行"
|
|
|
sheet1[count_row,9] = school
|
|
|
sheet1[count_row,10] = teacher_name
|
|
|
sheet1[count_row,11] = format_time(course.updatetime)
|
|
|
count_row += 1
|
|
|
end
|
|
|
book.write xls_report
|
|
|
xls_report.string
|
|
|
end
|
|
|
|
|
|
def shixun_task_xls shixun_task
|
|
|
xls_report = StringIO.new
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
sheet1 = book.create_worksheet :name => "course"
|
|
|
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
|
|
sheet1.row(0).default_format = blue
|
|
|
sheet1.row(0).concat(["ID","课堂名称","创建者","学生","实训作业","序号", "ID", "关卡数","作业名称","发布时间","截至时间","已提交作品","有效作品","通关","状态"])
|
|
|
count_row = 1
|
|
|
shixun_task.each_with_index do |shixun_task,index|
|
|
|
teacher_name = shixun_task.teacher ? shixun_task.teacher.show_real_name : ""
|
|
|
sheet1[count_row,0] = shixun_task.id
|
|
|
sheet1[count_row,1] = shixun_task.name
|
|
|
sheet1[count_row,2] = teacher_name
|
|
|
sheet1[count_row,3] = shixun_task.student.count
|
|
|
sheet1[count_row,4] = get_shixun_task(shixun_task.id).count
|
|
|
get_shixun_task(shixun_task.id).each_with_index do |gst, j|
|
|
|
sheet1[count_row,5] = get_hw_index(gst, @is_teacher, 4) + 1
|
|
|
sheet1[count_row,6] = gst.shixun.try(:identifier).nil? ? "--" : gst.shixun.try(:identifier)
|
|
|
sheet1[count_row,7] = gst.shixun.challenges.count
|
|
|
sheet1[count_row,8] = gst.name
|
|
|
sheet1[count_row,9] = format_time(gst.publish_time)
|
|
|
sheet1[count_row,10] = format_time(gst.end_time)
|
|
|
sheet1[count_row,11] = had_commit_studentwork_count(gst)
|
|
|
sheet1[count_row,12] = effective_shixun_work_count gst
|
|
|
sheet1[count_row,13] = tongguan_shixun_work_count gst
|
|
|
sheet1[count_row,14] = if HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 0
|
|
|
"未发布"
|
|
|
elsif HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 1
|
|
|
"提交中"
|
|
|
elsif HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 3
|
|
|
"匿评中"
|
|
|
elsif HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 4
|
|
|
"申诉中"
|
|
|
elsif HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 5
|
|
|
"评阅中"
|
|
|
else HomeworkDetailManual.where(:homework_common_id => gst.id).first.comment_status == 6
|
|
|
"已结束"
|
|
|
end
|
|
|
count_row += 1
|
|
|
end
|
|
|
end
|
|
|
book.write xls_report
|
|
|
xls_report.string
|
|
|
end
|
|
|
|
|
|
def readXlsData(xlsx)
|
|
|
doc = SimpleXlsxReader.open(xlsx)
|
|
|
sheet = doc.sheets.first
|
|
|
return sheet.rows
|
|
|
end
|
|
|
|
|
|
def competition_member_xls members, competition
|
|
|
xls_report = StringIO.new
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
sheet1 = book.create_worksheet :name => "报名列表"
|
|
|
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
|
|
sheet1.row(0).default_format = blue
|
|
|
count_row = 1
|
|
|
records = competition.competition_teams
|
|
|
if competition.identifier == "gcc-annotation-2018"
|
|
|
records.each do |team|
|
|
|
team[:s_score] = team.competition_scores.where(:competition_id => competition.id).first.try(:score).to_f.try(:round, 3)
|
|
|
end
|
|
|
records = records.sort do |a, b|
|
|
|
[b[:s_score]] <=> [a[:s_score]]
|
|
|
end
|
|
|
elsif competition.identifier == "gcc-dev-2018"
|
|
|
pre_stage = competition.competition_stages.where(:name => "预赛").first
|
|
|
final_stage = competition.competition_stages.where(:name => "决赛").first
|
|
|
records.each do |team|
|
|
|
# 决赛记录
|
|
|
f_score = team.competition_scores.where(:competition_stage_id => final_stage.try(:id)).first
|
|
|
# 预赛记录
|
|
|
p_score = team.competition_scores.where(:competition_stage_id => pre_stage.try(:id)).first
|
|
|
team[:s_score] = (f_score.try(:score).to_f * 0.85 + p_score.try(:score).to_f * 0.15).try(:round, 2)
|
|
|
team[:s_spend_time] = f_score.try(:cost_time).to_i + p_score.try(:cost_time).to_i
|
|
|
end
|
|
|
records = records.sort do |a, b|
|
|
|
[b[:s_score], a[:s_spend_time]] <=> [a[:s_score], b[:s_spend_time]]
|
|
|
end
|
|
|
elsif competition.identifier == 'hn'
|
|
|
pre_stage = competition.competition_stages.where(:name => "预赛").first
|
|
|
final_stage = competition.competition_stages.where(:name => "决赛").first
|
|
|
records.each do |team|
|
|
|
f_score = team.competition_scores.where(:competition_stage_id => final_stage.try(:id)).first
|
|
|
p_score = team.competition_scores.where(:competition_stage_id => pre_stage.try(:id)).first
|
|
|
team[:s_score] = (f_score.try(:score).to_f * 0.8 + p_score.try(:score).to_f * 0.2).try(:round, 2)
|
|
|
team[:s_spend_time] = f_score.try(:cost_time).to_i + p_score.try(:cost_time).to_i
|
|
|
end
|
|
|
records = records.sort do |a, b|
|
|
|
[b[:s_score], a[:s_spend_time]] <=> [a[:s_score], b[:s_spend_time]]
|
|
|
end
|
|
|
end
|
|
|
if competition.max_num > 1
|
|
|
sheet1.row(0).concat(["序号", "战队ID", "战队名称","指导老师", "队员姓名", "学号", "实名认证", "职业认证", "学校名称", "地区", "报名时间", "排名"])
|
|
|
members.each_with_index do |member, index|
|
|
|
member_user = member.user
|
|
|
sheet1[count_row,0] = index + 1
|
|
|
sheet1[count_row,1] = member.competition_team.try(:id)
|
|
|
sheet1[count_row,2] = member.competition_team.try(:name)
|
|
|
sheet1[count_row,3] = member.competition_team.teacher.try(:show_real_name)
|
|
|
sheet1[count_row,4] = member_user.try(:show_real_name)
|
|
|
sheet1[count_row,5] = member_user.try(:student_id)
|
|
|
sheet1[count_row,6] = member_user.try(:authentication_status)
|
|
|
sheet1[count_row,7] = member_user.try(:professional_status)
|
|
|
sheet1[count_row,8] = member_user.try(:school_name)
|
|
|
sheet1[count_row,9] = member_user.user_extensions.school.try(:province)
|
|
|
sheet1[count_row,10] = format_time member.created_at
|
|
|
sheet1[count_row,11] = records.present? ? (records.map(&:id).index(member.competition_team_id).to_i + 1) : "--"
|
|
|
count_row += 1
|
|
|
end
|
|
|
else
|
|
|
sheet1.row(0).concat(["序号","姓名","学号","实名认证", "职业认证", "学校名称","地区", "报名时间", "排名"])
|
|
|
members.each_with_index do |member, index|
|
|
|
member_user = member.user
|
|
|
sheet1[count_row,0] = index + 1
|
|
|
sheet1[count_row,1] = member_user.try(:show_real_name)
|
|
|
sheet1[count_row,2] = member_user.try(:student_id)
|
|
|
sheet1[count_row,3] = member_user.try(:authentication_status)
|
|
|
sheet1[count_row,4] = member_user.try(:professional_status)
|
|
|
sheet1[count_row,5] = member_user.try(:school_name)
|
|
|
sheet1[count_row,6] = member_user.user_extensions.school.try(:province)
|
|
|
sheet1[count_row,7] = format_time member.created_at
|
|
|
sheet1[count_row,8] = records.present? ? (records.map(&:id).index(member.competition_team_id).to_i + 1) : "--"
|
|
|
count_row += 1
|
|
|
end
|
|
|
end
|
|
|
book.write xls_report
|
|
|
xls_report.string
|
|
|
end
|
|
|
|
|
|
def published_subject_xls subjects
|
|
|
xls_report = StringIO.new
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
sheet1 = book.create_worksheet :name => "已发布实训课程"
|
|
|
count_row = 2
|
|
|
sheet1.row(1).concat(["", "地址", "实训课程名称","章节名称", "实训组成", "关卡数", "状态", "更新时间"])
|
|
|
Rails.logger.warn("##########subjects:#{subjects.count}")
|
|
|
subjects.each do |subject|
|
|
|
sheet1[count_row,1] = "paths/"+subject.id.to_s
|
|
|
sheet1[count_row,2] = subject.name
|
|
|
if subject.stages.count > 0
|
|
|
subject.stages.each_with_index do |stage, s_index|
|
|
|
sheet1[count_row,3] = stage.name
|
|
|
if stage.shixuns.count > 0
|
|
|
stage.shixuns.each_with_index do |shixun, index|
|
|
|
sheet1[count_row,4] = "#{s_index + 1}-#{index + 1} #{shixun.name}"
|
|
|
sheet1[count_row,5] = shixun.challenges.count
|
|
|
sheet1[count_row,6] = shixun.shixun_status
|
|
|
if s_index == 0 && index == 0
|
|
|
sheet1[count_row,7] = format_time subject.updated_at
|
|
|
end
|
|
|
count_row += 1
|
|
|
end
|
|
|
else
|
|
|
if s_index == 0
|
|
|
sheet1[count_row,7] = format_time subject.updated_at
|
|
|
end
|
|
|
count_row += 1
|
|
|
end
|
|
|
end
|
|
|
else
|
|
|
sheet1[count_row,7] = format_time subject.updated_at
|
|
|
count_row += 1
|
|
|
end
|
|
|
end
|
|
|
book.write xls_report
|
|
|
xls_report.string
|
|
|
end
|
|
|
end
|