From f252438f853ec5ceae7395c0cbe9be810d35de81 Mon Sep 17 00:00:00 2001 From: z9hang Date: Mon, 5 Jan 2015 17:47:04 +0800 Subject: [PATCH 1/9] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E7=BC=96=E8=BE=91?= =?UTF-8?q?=E8=AF=BE=E7=A8=8B=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/courses.rb | 5 +++-- app/controllers/courses_controller.rb | 2 +- app/services/courses_service.rb | 5 +++-- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/app/api/mobile/apis/courses.rb b/app/api/mobile/apis/courses.rb index 2e514b6e9..c36abbd8d 100644 --- a/app/api/mobile/apis/courses.rb +++ b/app/api/mobile/apis/courses.rb @@ -65,12 +65,13 @@ module Mobile requires :is_public, type: Integer, desc: '是否公开 1公开 0私有' requires :open_student, type: Integer, desc: '是否公开学生列表1公开,0不公开,不公开时非课程成员无法看到学生列表' requires :course_type, type:Integer, desc: '暂时传1' - requires :term, type: String, desc: '学期(秋秀学期或春秀学期)' + requires :term, type: String, desc: '学期(秋季学期或春季学期)' requires :time, type: String, desc: '年份' requires :class_period, type: String, desc: '学时总数' end post do authenticate! + cs = CoursesService.new cs_params = { course: params.reject{|k,v| [:term,:time,:class_period].include?(k)}, term: params[:term], @@ -79,7 +80,7 @@ module Mobile } course = ::Course.find(params[:course_id]) cs.edit_course_authorize(current_user,course) - course = cs.edit_course(cs_params, course) + course = cs.edit_course(cs_params, course,current_user) present :data, course, with: Mobile::Entities::Course present :status, 0 end diff --git a/app/controllers/courses_controller.rb b/app/controllers/courses_controller.rb index 985c33aab..19cca8e70 100644 --- a/app/controllers/courses_controller.rb +++ b/app/controllers/courses_controller.rb @@ -95,7 +95,7 @@ class CoursesController < ApplicationController #更新课程信息 def update cs = CoursesService.new - @course = cs.edit_course params,@course + @course = cs.edit_course params,@course,User.current if @course.errors.full_messages.count <= 0 respond_to do |format| format.html { diff --git a/app/services/courses_service.rb b/app/services/courses_service.rb index 3f025c892..b9489be4e 100644 --- a/app/services/courses_service.rb +++ b/app/services/courses_service.rb @@ -175,8 +175,9 @@ class CoursesService #params[:term]:学期(秋季学期或春季学期) #params[:time]: 年份(例:2014) #params[:class_period]:学时总数 - def edit_course params,course - course.safe_attributes = params[:course] + def edit_course(params,course,current_user) + course.send(:safe_attributes=, params[:course], current_user) + #course.safe_attributes = params[:course] course.time = params[:time] course.term = params[:term] course.class_period = params[:class_period] From ed776fa9b9149e562a77d9aa7d30bc7a74c142a9 Mon Sep 17 00:00:00 2001 From: z9hang Date: Tue, 6 Jan 2015 16:51:44 +0800 Subject: [PATCH 2/9] =?UTF-8?q?1=E3=80=81=E4=BF=AE=E6=AD=A3=E7=94=A8?= =?UTF-8?q?=E6=88=B7=E7=BC=96=E8=BE=91=E6=8E=A5=E5=8F=A3=E6=8A=A5=E9=94=99?= =?UTF-8?q?=E9=97=AE=E9=A2=98=E3=80=822=E3=80=81=E4=BF=AE=E6=AD=A3?= =?UTF-8?q?=E7=94=A8=E6=88=B7=E6=B3=A8=E5=86=8C=EF=BC=8C=E7=BC=96=E8=BE=91?= =?UTF-8?q?=E7=94=A8=E6=88=B7=E6=8E=A5=E5=8F=A3=E8=BF=94=E5=9B=9E=E6=95=B0?= =?UTF-8?q?=E6=8D=AE=E4=B8=8D=E6=AD=A3=E7=A1=AE=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/users.rb | 2 +- app/api/mobile/entities/user.rb | 7 ++++++- app/services/users_service.rb | 12 ++++++++++-- 3 files changed, 17 insertions(+), 4 deletions(-) diff --git a/app/api/mobile/apis/users.rb b/app/api/mobile/apis/users.rb index a566b702d..5d1455a78 100644 --- a/app/api/mobile/apis/users.rb +++ b/app/api/mobile/apis/users.rb @@ -35,7 +35,7 @@ module Mobile authenticate! us = UsersService.new ue = us.edit_user params.merge(id: current_user.id) - present :data, ue.user, with: Mobile::Entities::User + present :data, ue,with: Mobile::Entities::User present :status, 0 end diff --git a/app/api/mobile/entities/user.rb b/app/api/mobile/entities/user.rb index 3c3356b46..2a4c0cdaa 100644 --- a/app/api/mobile/entities/user.rb +++ b/app/api/mobile/entities/user.rb @@ -3,7 +3,12 @@ module Mobile class User < Grape::Entity def self.user_expose(f) expose f do |u,opt| - u.send(f) if u.respond_to?(f) + if u.is_a?(Hash) && u.key?(f) + u[f] + #else + # u.send(f) if u.respond_to?(f) + end + end end diff --git a/app/services/users_service.rb b/app/services/users_service.rb index c58956994..82b88befb 100644 --- a/app/services/users_service.rb +++ b/app/services/users_service.rb @@ -36,7 +36,11 @@ class UsersService ue.user_id = @user.id ue.save end - @user + img_url = url_to_avatar(@user) + gender = @user.user_extensions.gender.nil? ? 0 : @user.user_extensions.gender + work_unit = get_user_work_unit @user + location = get_user_location @user + {:id => @user.id, :img_url => img_url, :nickname => @user.login, :gender => gender, :work_unit => work_unit, :mail => @user.mail, :location => location, :brief_introduction => @user.user_extensions.brief_introduction} end #显示用户 @@ -95,7 +99,11 @@ class UsersService logger.error "[Error] avatar : users_service#edit_user ===> #{e}" end end - [:user_extensions =>@se,:img_url => url_to_avatar(@user),:work_unit => get_user_work_unit(@user),:location => get_user_location(@user)] + img_url = url_to_avatar(@user) + gender = @user.user_extensions.gender.nil? ? 0 : @user.user_extensions.gender + work_unit = get_user_work_unit @user + location = get_user_location @user + {:id => @user.id, :img_url => img_url, :nickname => @user.login, :gender => gender, :work_unit => work_unit, :mail => @user.mail, :location => location, :brief_introduction => @user.user_extensions.brief_introduction} end #获取用户的工作单位 From 1686ed4fbdadfe3c9ec531e8b6f2d93e48ea69eb Mon Sep 17 00:00:00 2001 From: z9hang Date: Tue, 6 Jan 2015 16:59:22 +0800 Subject: [PATCH 3/9] =?UTF-8?q?=E8=A1=A5=E4=B8=8A=E6=98=BE=E7=A4=BA?= =?UTF-8?q?=E7=94=A8=E6=88=B7=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/users.rb | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/app/api/mobile/apis/users.rb b/app/api/mobile/apis/users.rb index 5d1455a78..e15fdb16b 100644 --- a/app/api/mobile/apis/users.rb +++ b/app/api/mobile/apis/users.rb @@ -20,6 +20,16 @@ module Mobile present :status, 0 end + desc "显示用户" + params do + + end + get ':id' do + us = UsersService.new + ue = us.show_user params + present :data, ue,with: Mobile::Entities::User + present :status, 0 + end desc "修改用户" params do From d407f8656d518544f9f3d859990f9278724219e1 Mon Sep 17 00:00:00 2001 From: z9hang Date: Tue, 6 Jan 2015 17:46:16 +0800 Subject: [PATCH 4/9] =?UTF-8?q?1=E3=80=81=E4=BF=AE=E5=A4=8D=E8=AF=BE?= =?UTF-8?q?=E7=A8=8Bimg=5Furl=E4=B8=BA=E7=A9=BA=E9=97=AE=E9=A2=98=E3=80=82?= =?UTF-8?q?2=E3=80=81=E8=A1=A5=E4=B8=8A=E7=94=A8=E6=88=B7=E8=AF=BE?= =?UTF-8?q?=E7=A8=8B=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/users.rb | 12 ++++++++++++ app/api/mobile/entities/course.rb | 3 ++- app/services/users_service.rb | 6 +++++- 3 files changed, 19 insertions(+), 2 deletions(-) diff --git a/app/api/mobile/apis/users.rb b/app/api/mobile/apis/users.rb index e15fdb16b..878748793 100644 --- a/app/api/mobile/apis/users.rb +++ b/app/api/mobile/apis/users.rb @@ -49,6 +49,18 @@ module Mobile present :status, 0 end + desc '获取用户课程' + params do + + end + + get ':id/courses' do + us = UsersService.new + ue = us.user_courses_list params,current_user.nil? ? User.find(2):current_user + present :data, ue,with: Mobile::Entities::Course + present :status, 0 + end + desc '修改密码' params do diff --git a/app/api/mobile/entities/course.rb b/app/api/mobile/entities/course.rb index 0dd0d6aeb..ffae1db1f 100644 --- a/app/api/mobile/entities/course.rb +++ b/app/api/mobile/entities/course.rb @@ -10,7 +10,8 @@ module Mobile c = f[:course] end if field == :img_url - f.img_url if f.respond_to?(:img_url) + f[field] if f.is_a?(Hash) && f.key?(field) + #f.img_url if f.respond_to?(:img_url) else (c[field] if (c.is_a?(Hash) && c.key?(field))) || (c.send(field) if c.respond_to?(field)) end diff --git a/app/services/users_service.rb b/app/services/users_service.rb index 82b88befb..c1074c1c0 100644 --- a/app/services/users_service.rb +++ b/app/services/users_service.rb @@ -146,7 +146,11 @@ class UsersService membership = @user.coursememberships.all(:conditions => Course.visible_condition(User.current)) end membership.sort! {|older, newer| newer.created_on <=> older.created_on } - membership + course_list = [] + membership.each do |mp| + course_list << {:course => mp.course,:img_url => url_to_avatar(mp.course)} + end + course_list end #修改密码 From b711793d7ce468db39f3ebeeca1eafa54f3d7fd3 Mon Sep 17 00:00:00 2001 From: z9hang Date: Wed, 7 Jan 2015 11:20:27 +0800 Subject: [PATCH 5/9] =?UTF-8?q?=E4=BF=AE=E6=AD=A3=E5=8A=A0=E5=85=A5?= =?UTF-8?q?=E8=AF=BE=E7=A8=8B=E6=8E=A5=E5=8F=A3=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/courses.rb | 7 ++++--- app/controllers/courses_controller.rb | 4 +++- app/services/courses_service.rb | 11 ++++++----- 3 files changed, 13 insertions(+), 9 deletions(-) diff --git a/app/api/mobile/apis/courses.rb b/app/api/mobile/apis/courses.rb index 79a5c215e..0ae3bba1d 100644 --- a/app/api/mobile/apis/courses.rb +++ b/app/api/mobile/apis/courses.rb @@ -90,13 +90,14 @@ module Mobile desc "加入课程" params do requires :token, type: String + requires :course_password, type: String end post ":id" do authenticate! cs = CoursesService.new - status = cs.join_course({"object_id" => params[:id]},current_user) - out = {status: status} - message = case status + status = cs.join_course({:object_id => params[:id],:course_password => params[:course_password]},current_user) + out = {status: status[:state]} + message = case status[:state] when 0; "加入成功" when 1; "密码错误" when 2; "课程已过期 请联系课程管理员重启课程。(在配置课程处)" diff --git a/app/controllers/courses_controller.rb b/app/controllers/courses_controller.rb index 19cca8e70..fa76bd0e5 100644 --- a/app/controllers/courses_controller.rb +++ b/app/controllers/courses_controller.rb @@ -27,7 +27,9 @@ class CoursesController < ApplicationController def join if User.current.logged? cs = CoursesService.new - @state,course = cs.join_course params + join = cs.join_course params,User.current + @state = join[:state] + course = join[:course] #course = Course.find_by_id params[:object_id] #if course # if course_endTime_timeout? course diff --git a/app/services/courses_service.rb b/app/services/courses_service.rb index b9489be4e..23c25d302 100644 --- a/app/services/courses_service.rb +++ b/app/services/courses_service.rb @@ -217,20 +217,21 @@ class CoursesService #@state == 4 您加入的课程不存在 #@state == 5 您还未登录 #@state 其他 未知错误,请稍后再试 - def join_course params + def join_course params,current_user course = Course.find_by_id params[:object_id] + @state = 10 if course if course_endTime_timeout? course @state = 2 else - if User.current.member_of_course?(course) + if current_user.member_of_course?(course) @state = 3 else if params[:course_password] == course.password members = [] - members << Member.new(:role_ids => [10], :user_id => User.current.id) + members << Member.new(:role_ids => [10], :user_id => current_user.id) course.members << members - StudentsForCourse.create(:student_id => User.current.id, :course_id => params[:object_id]) + StudentsForCourse.create(:student_id => current_user.id, :course_id => params[:object_id]) @state = 0 else @state = 1 @@ -240,7 +241,7 @@ class CoursesService else @state = 4 end - [@state,course] + {:state => @state,:course => course} end #作业列表 From 303752fc7e0a5f2360d6cdc7863d9d0eb9e331c4 Mon Sep 17 00:00:00 2001 From: z9hang Date: Wed, 7 Jan 2015 11:37:48 +0800 Subject: [PATCH 6/9] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E9=80=80=E5=87=BA?= =?UTF-8?q?=E8=AF=BE=E7=A8=8B=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/courses.rb | 11 +++++++++-- app/services/courses_service.rb | 15 ++++++++++++++- 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/app/api/mobile/apis/courses.rb b/app/api/mobile/apis/courses.rb index 0ae3bba1d..d3f0e8cef 100644 --- a/app/api/mobile/apis/courses.rb +++ b/app/api/mobile/apis/courses.rb @@ -116,8 +116,15 @@ module Mobile delete ":id" do authenticate! cs = CoursesService.new - cs.exit_course({"object_id" => params[:id]}, current_user) - {status: 0} + status = cs.exit_course({:object_id => params[:id]}, current_user) + out = {status: status} + message = case status + when 0; "退出成功" + when 1; "您不在课程中" + when 2; "您还未登录" + else; "未知错误,请稍后再试" + end + out.merge(message: message) end desc "搜索课程" diff --git a/app/services/courses_service.rb b/app/services/courses_service.rb index 23c25d302..d8dd8299b 100644 --- a/app/services/courses_service.rb +++ b/app/services/courses_service.rb @@ -197,14 +197,27 @@ class CoursesService #退出课程 #object_id: 课程id #user:当前用户 + #@state == 0 退出成功 + #@state == 1 不在课程中 + #@state == 2 您还未登录 + #@state 其他 未知错误,请稍后再试 def exit_course params,user + if user.nil? + @state = 2 + return @state + end @member = Member.where('course_id = ? and user_id = ?', params[:object_id], user.id) + if @member.nil? || @member.count == 0 + @state = 1 + return @state + end @member.first.destroy - joined = StudentsForCourse.where('student_id = ? and course_id = ?', user.id, params[:object_id]) joined.each do |join| join.delete + @state = 0 end + @state end #加入课程 From fdb38c1b87043b11c3a146b7b01eaf71e23c18d5 Mon Sep 17 00:00:00 2001 From: z9hang Date: Wed, 7 Jan 2015 15:24:43 +0800 Subject: [PATCH 7/9] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E8=AF=BE=E7=A8=8B?= =?UTF-8?q?=E6=95=99=E5=B8=88=EF=BC=8C=E8=AF=BE=E7=A8=8B=E5=AD=A6=E7=94=9F?= =?UTF-8?q?=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/courses.rb | 14 +++++++++----- app/services/courses_service.rb | 31 ++++++++++++++++++++++++++++++- 2 files changed, 39 insertions(+), 6 deletions(-) diff --git a/app/api/mobile/apis/courses.rb b/app/api/mobile/apis/courses.rb index d3f0e8cef..4130ea902 100644 --- a/app/api/mobile/apis/courses.rb +++ b/app/api/mobile/apis/courses.rb @@ -140,22 +140,26 @@ module Mobile desc "课程老师列表" params do + requires :token, type: String requires :course_id, type: Integer, desc: "课程id" end get 'teachers' do cs = CoursesService.new - teachers = cs.course_teacher_or_student_list({role: 1}, params[:course_id],current_user) - {status: 0, data: teachers} + teachers = cs.course_teacher_or_student_list({role: '1'}, params[:course_id],current_user) + present :data, teachers, with: Mobile::Entities::User + present :status, 0 end desc "课程学生列表" params do + requires :token, type: String requires :course_id, type: Integer, desc: "课程id" end - get 'teachers' do + get 'students' do cs = CoursesService.new - teachers = cs.course_teacher_or_student_list({role: 2}, params[:course_id],current_user) - {status: 0, data: teachers} + students = cs.course_teacher_or_student_list({role: '2'}, params[:course_id],current_user) + present :data, students, with: Mobile::Entities::User + present :status, 0 end desc "返回单个课程" diff --git a/app/services/courses_service.rb b/app/services/courses_service.rb index d8dd8299b..485126ac4 100644 --- a/app/services/courses_service.rb +++ b/app/services/courses_service.rb @@ -72,7 +72,36 @@ class CoursesService #@subPage_title = '' @members = c.member_principals.includes(:roles, :principal).all.sort end - @members + users = [] + @members.each do |m| + img_url = url_to_avatar(m.user) + gender = m.user.user_extensions.gender.nil? ? 0 : m.user.user_extensions.gender + work_unit = get_user_work_unit m.user + location = get_user_location m.user + users << {:id => m.user.id, :img_url => img_url, :nickname => m.user.login, :gender => gender, :work_unit => work_unit, :mail => m.user.mail, :location => location, :brief_introduction => m.user.user_extensions.brief_introduction} + end + users + end + + #获取用户的工作单位 + def get_user_work_unit user + work_unit = "" + if user.user_extensions.identity == 0 || user.user_extensions.identity == 1 + work_unit = user.user_extensions.school.name unless user.user_extensions.school.nil? + elsif user.user_extensions.identity == 3 + work_unit = user.user_extensions.occupation + elsif user.user_extensions.identity == 2 + work_unit = user.firstname + end + work_unit + end + + #获取用户地区 + def get_user_location user + location = "" + location << (user.user_extensions.location || '') + location << (user.user_extensions.location_city || '') + location end #课程通知列表 From fd1dc80bf0760fa35cc9a8f372ee1f3c74dda8e7 Mon Sep 17 00:00:00 2001 From: z9hang Date: Wed, 7 Jan 2015 16:02:16 +0800 Subject: [PATCH 8/9] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E4=BD=9C=E4=B8=9A?= =?UTF-8?q?=E8=AF=A6=E6=83=85=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/homeworks.rb | 3 ++- app/services/homework_service.rb | 9 +++++---- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/app/api/mobile/apis/homeworks.rb b/app/api/mobile/apis/homeworks.rb index 99acfd87f..0b86fef7b 100644 --- a/app/api/mobile/apis/homeworks.rb +++ b/app/api/mobile/apis/homeworks.rb @@ -16,7 +16,8 @@ module Mobile end route_param :id do get do - get_service.show_homework params + hs = HomeworkService.new + hs.show_homework params end end diff --git a/app/services/homework_service.rb b/app/services/homework_service.rb index 914889c68..c0a669bca 100644 --- a/app/services/homework_service.rb +++ b/app/services/homework_service.rb @@ -13,16 +13,17 @@ class HomeworkService def show_homework params @bid = Bid.find(params[:id]) course = @bid.courses.first - author = @bid.author.firstname + @bid.author.lastname + author = @bid.author.lastname + @bid.author.firstname many_times = course.homeworks.index(@bid) + 1 name = @bid.name - homework_count = @bid.homeworks.count + homework_count = @bid.homeworks.count #已提交的作业数量 + student_questions_count = @bid.commit.nil? ? 0 : @bid.commit description = @bid.description if is_course_teacher(User.current, course) && @bid.open_anonymous_evaluation == 1 && @bid.homeworks.count >= 2 state = bid.comment_status end - {:course => 'course', :atuthor => 'author', :many_times => 'many_times', :name => 'name', :homework_count => 'homework_count', - :descriptiong => 'description', :state => 'state'} + {:course => course, :atuthor => author, :many_times => many_times, :name => name, :homework_count => homework_count,:student_questions_count => student_questions_count, + :descriptiong => description, :state => state} end # 启动作业匿评 From da880dae00d25d52e90485eea8e7ce0b5a9116cb Mon Sep 17 00:00:00 2001 From: guange <8863824@gmail.com> Date: Sat, 10 Jan 2015 21:31:16 +0800 Subject: [PATCH 9/9] =?UTF-8?q?=E4=BD=9C=E4=B8=9A=E5=B1=95=E7=A4=BA?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/api/mobile/apis/homeworks.rb | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/app/api/mobile/apis/homeworks.rb b/app/api/mobile/apis/homeworks.rb index 99acfd87f..9eef00094 100644 --- a/app/api/mobile/apis/homeworks.rb +++ b/app/api/mobile/apis/homeworks.rb @@ -16,14 +16,13 @@ module Mobile end route_param :id do get do + p self get_service.show_homework params end end - - - end + end end end