# encoding=utf-8 # 外部数据分析专用 class SourcesService include ApplicationHelper include GamesHelper LIMIT = 10 # shixuns start ############################################ def shixun_index params #offset = params[:page].to_i * 15 #Shixun.select([:id, :identifier]).offset(offset).limit(15) Shixun.select([:id, :name,:identifier, :created_at]).where("created_at < ?", params[:time]) end def shixun_detail params shixun = Shixun.select([:id, :identifier, :name, :description, :user_id, :myshixuns_count, :evaluate_script, :propaedeutics, :challenges_count, :gpid, :created_at, :updated_at]).find_by_identifier(params[:identifier]) return {:status => 404} unless shixun.present? g = Gitlab.client git_url = "#{Redmine::Configuration['gitlab_address']}/#{g.project(shixun.try(:gpid)).try(:path_with_namespace)}.git" language = shixun.mirror_repositories.first.try(:type_name) homework_common_ids = HomeworkCommonsShixuns.where(:shixun_id => shixun.id).pluck(:homework_common_id) course_ids = HomeworkCommon.where(:id => homework_common_ids).pluck(:course_id) course_info =[] course_ids.each do |id| course= Course.select([:name]).find id course_info << {course_id: id, course_name: course.name} end list = shixun.try(:attributes).merge({:git_url => git_url, :language => language, :course_info => course_info}) return list end def shixun_challenges params list = [] shixun = Shixun.find_by_identifier(params[:identifier]) return {:status => 404} unless shixun.present? shixun.challenges.each do |challenge| sets = [] challenge.test_sets.each do |set| sets << {input: set.input, output: set.output} end list << {:id => challenge.id, :name => challenge.subject, :shixun_id => challenge.shixun_id, :task_pass => challenge.task_pass, :position => challenge.position, :answer => challenge.answer, :score => challenge.score, :path => challenge.path, :difficulty => challenge.difficulty, :user_id => shixun.user_id, :sets => sets} end return list end def get_tpi_info params shixun = Shixun.find_by_identifier params[:identifier] page = params[:page].to_i offset = page * 10 challenge_paths = shixun.challenges.pluck(:path) myshixuns = shixun.myshixuns.select([:id, :user_id, :gpid, :shixun_id]).offset(offset).limit(10) g = Gitlab.client tpi_info = [] myshixuns.each do |myshixun| code_info = [] challenge_paths.each do |paths| x_paths = paths.split(";") x_paths.each do |path| Rails.logger.info("############################gpid: #{myshixun.gpid}") Rails.logger.info("############################path: #{path}") code = g.files(myshixun.gpid, path, "master").try(:content) code = tran_base64_decode64(code) # 取begin和end之间的代码 if code.present? user_code = code.match(/\/\*+ Begin \*+\/(\S*)\/\*+ End \*+\//) coder = user_code[1] if code.length == 2 end code_info << {path: path, code: code} end end tpi_info << {user_id: myshixun.user_id, code: code_info} end {tpi_info: tpi_info} end # paths start ########################### def get_paths_info params path = Subject.find params[:id] stages = path.stages.order("position asc") path_info = [] stages.each do |stage| chapter_name = stage.name chapter_shixuns = [] stage.stage_shixuns.each do |stage_shixun| challenges = stage_shixun.shixun.challenges challenge_info = [] challenges.each do |challenge| challenge_info << {challenge_id: challenge.id, challenge_name: challenge.subject} end chapter_shixuns << {name: stage_shixun.shixun.name, identifier: stage_shixun.shixun.identifier, challenge_info: challenge_info} end path_info << {chapter_name: chapter_name, chapter_shixuns: chapter_shixuns} end { path_info: path_info} end # games start ############################################ def myshixuns_index params endTime = Time.parse(params[:time].to_s) beginTime = Time.parse(params[:begin_time].to_s) offset = ((params[:page] || 1).to_i - 1) * 50 Myshixun.select([:id, :user_id, :shixun_id]).where("created_at < ? and created_at > ?", endTime, beginTime).offset(offset).limit(50) end def search_myshixun params myshixun = Myshixun.where(:shixun_id => params[:shixun_id], :user_id => params[:user_id]).first return {:status => 404} unless myshixun.present? g = Gitlab.client git_url = "#{Redmine::Configuration['gitlab_address']}/#{g.project(myshixun.try(:gpid)).try(:path_with_namespace)}.git" {:status => myshixun.status, :git_url => git_url, :shixun_id => myshixun.shixun_id, :user_id => myshixun.user_id} end def games params time = Time.parse(params[:time].to_s) offset = ((params[:page] || 1).to_i - 1) * 50 Game.select([:id, :identifier, :user_id, :myshixun_id]).where("created_at < ?", time).offset(offset).limit(50) end # 关卡详情 def game_detail params game = Game.min.find_by_identifier(params[:identifier]) myshixun = game.myshixun return {:status => 404} unless game.present? challenge = Challenge.min.find(game.challenge_id) outputs_commit_count = Output.find_by_sql("select count(*) as commit_count from outputs where game_id=#{game.id} and test_set_position=1").first.try(:commit_count) right = game.status == 2 ? true : false type = challenge.st g = Gitlab.client last_code = game.game_codes.pluck(:new_code) commit_status = [] game.outputs.group(:query_index).each_with_index do |output, index| result = output.code == 0 ? true : false commit_status << {commit_time: output.created_at, commit_result: result} end git_url = "#{Redmine::Configuration['gitlab_address']}/#{g.project(myshixun.try(:gpid)).try(:path_with_namespace)}.git" {:id => game.id, :identifier => game.identifier, :commit_count => outputs_commit_count, :right => right, :type => type, :myshixun_id => game.myshixun_id, :final_Score => game.final_score, :git_url => git_url, shixun_id: myshixun.shixun_id, challenge_id: challenge.id, :last_commit_code => last_code, commit_status: commit_status} end # 搜索学员开启的关卡 def search_game params shixun_id = Challenge.where(:id => params[:challenge_id]).pluck(:shixun_id).first myshixun_id = Myshixun.where(:shixun_id => shixun_id, :user_id => params[:user_id]).pluck(:id).first game = Game.where(:myshixun_id => myshixun_id, :challenge_id => params[:challenge_id]).first if game.present? return {:id => game.id, :identifier => game.identifier} else return {:status => 404} end end # users start ############################################ def users params time = Time.parse("#{params[:time]}") users = User.select([:id, :login, :created_on, :firstname, :lastname, :nickname]).includes(user_extensions: :school).where("created_on < ?", time) users = users.map{|user| {id: user.id, login: user.login, username: user.show_real_name, school: user.school_name, work: user.identity, sex: user.sex, created_on: user.created_on}} end def login params user, last_login_on = User.try_to_login(params[:username], params[:password]) return {status: -1, message: '账号或密码错误!'} if user.blank? {status: 1, user_id: user.id, message: "登陆成功!"} end def get_user_info params user = User.find params[:id] mail = user.mail.presence || "login@educoder.net" {username: user.show_real_name, user_id: user.id, email: mail, phone: user.phone, sex: user.sex, school_name: user.school_name} end # courses start ############################################ def course_detail params course = Course.select([:id, :name, :tea_id, :time, :term, :class_period, :school_id, :description, :end_time, :end_term, :visits, :credit, :end_date, :members_count, :homework_commons_count]).find(params[:id]) if course.present? return course.try(:attributes) else return {:status => 404} end end def courses params time = Time.parse("#{params[:time]}") Course.select([:id, :name, :created_at]).where("created_at < ?", time) end def exercises params time = Time.parse("#{params[:time]}") Exercise.select([:id, :exercise_name, :created_at]).where("created_at < ?", time) end def exercise_detail params exercise = Exercise.find params[:id] if exercise.present? return exercise.try(:attributes) else return {:status => 404} end end def get_exercise_questions params exercise = Exercise.find params[:id] exercise_list = [] exercise.exercise_questions.each do |question| title = if question.question_type == 1 || question.question_type == 2 question.exercise_choices.pluck(:choice_text) else [] end right_answer = if question.question_type == 1 || question.question_type == 2 choice_id = question.exercise_standard_answers.first.try(:exercise_choice_id) choice_ids = choice_id.to_s.split("") if choice_id question.exercise_choices.where(:choice_position => choice_ids).pluck(:choice_text) elsif question.question_type == 5 [] else question.exercise_standard_answers.pluck(:answer_text) end exercise_list << {choice_id: choice_id, id: question.id, name: question.question_title, type: question.question_type_name, title: title, right_answer: right_answer, score: question.question_score} end {exercise_id: exercise.id, exercise_name: exercise.exercise_name, course_id: exercise.course_id, course_name: exercise.course.name, exercise_list: exercise_list} end # 竞赛相关 ################################################### def get_competition_members params comp = Competition.find_by_identifier params[:identifier] team_ids = comp.competition_teams.pluck(:id) user_team = TeamMember.where(:competition_team_id => team_ids, :user_id => params[:user_id]).first user_ids =TeamMember.where(:competition_team_id => user_team.try(:competition_team_id)).pluck(:user_id) {team_user_ids: user_ids} end def get_team_ids params comp = Competition.find_by_identifier params[:identifier] team_ids = comp.competition_teams.pluck(:id) {team_ids: team_ids} end def get_team_user_ids params comp = CompetitionTeam.find params[:team_id] user_ids = comp.team_members.pluck(:user_id) {user_ids: user_ids} end def get_user_competition_id params competition_ids = Competition.where(:identifier => params[:identifier]).pluck(:id) team_id = TeamMember.where(:user_id => params[:educoder_userid], :competition_id => competition_ids).pluck(:competition_team_id) {team_id: team_id} end def get_team_info params comp = Competition.find_by_identifier(params[:identifier]) if comp team_info = [] teams = comp.competition_teams teams.each do |t| team_member = [] t.team_members.each do |m| user = User.find m.user_id team_member << {user_id: m.user_id, user_name: user.show_real_name} end team_info << {team_id: t.id, team_name: t.name, team_member: team_member} end {team_info: team_info} end end def shixun_homework_commons params HomeworkCommon.where(:homework_type => 4, :course_id => params[:id]) end end