2014-12-10 18:26:38 +08:00
|
|
|
|
#coding=utf-8
|
2014-11-27 19:43:04 +08:00
|
|
|
|
module Mobile
|
2014-12-09 15:16:47 +08:00
|
|
|
|
module Apis
|
2014-12-09 16:36:43 +08:00
|
|
|
|
class Users < Grape::API
|
|
|
|
|
resource :users do
|
2014-12-04 10:11:55 +08:00
|
|
|
|
|
2016-06-20 14:39:20 +08:00
|
|
|
|
desc "查询是否已绑定"
|
|
|
|
|
params do
|
|
|
|
|
requires :openid, type: String, desc: 'wechat openid'
|
|
|
|
|
end
|
|
|
|
|
post 'isbind' do
|
|
|
|
|
openid = params[:openid]
|
|
|
|
|
uw = UserWechat.where(openid: openid).first
|
|
|
|
|
raise "还未绑定trustie帐户" unless uw
|
|
|
|
|
|
|
|
|
|
user = uw.user
|
|
|
|
|
::ApiKey.delete_all(user_id: user.id)
|
|
|
|
|
key = ::ApiKey.create!(user_id: user.id)
|
|
|
|
|
present status: 0, token: key.access_token
|
|
|
|
|
end
|
2016-06-17 18:18:03 +08:00
|
|
|
|
|
|
|
|
|
desc "绑定微信用户"
|
|
|
|
|
params do
|
|
|
|
|
requires :login, type: String, desc: 'username'
|
|
|
|
|
requires :password, type: String, desc: 'password'
|
|
|
|
|
end
|
2016-06-17 18:42:58 +08:00
|
|
|
|
post 'wxbind' do
|
2016-06-22 12:11:34 +08:00
|
|
|
|
openid = session[:wechat_openid]
|
|
|
|
|
logger.debug "openid ============== #{openid}"
|
2016-08-12 09:23:09 +08:00
|
|
|
|
raise "无法获取到openid,请在微信中打开本页面" unless openid
|
2016-06-17 18:54:24 +08:00
|
|
|
|
uw = UserWechat.where(openid: openid).first
|
2016-08-13 14:39:15 +08:00
|
|
|
|
raise "此微信号已绑定用户(#{uw.user.login}), 不能重复绑定" if uw && uw.real?
|
2016-06-17 18:37:26 +08:00
|
|
|
|
|
2016-06-17 18:50:43 +08:00
|
|
|
|
user, last_login_on = User.try_to_login(params[:login], params[:password])
|
2016-06-17 18:37:26 +08:00
|
|
|
|
raise "用户名或密码错误,请重新输入" unless user
|
|
|
|
|
#补全用户信息
|
|
|
|
|
|
|
|
|
|
raise "此用户已经绑定过公众号, 请换一个帐户试试" if user.user_wechat
|
|
|
|
|
|
2016-08-14 10:46:17 +08:00
|
|
|
|
if uw && !uw.real?
|
2016-08-13 14:39:15 +08:00
|
|
|
|
uw.migrate_user(user)
|
|
|
|
|
else
|
|
|
|
|
UserWechat.create!(
|
2016-06-17 18:37:26 +08:00
|
|
|
|
openid: openid,
|
|
|
|
|
user: user
|
2016-08-13 14:39:15 +08:00
|
|
|
|
)
|
|
|
|
|
end
|
|
|
|
|
|
2016-07-14 11:16:45 +08:00
|
|
|
|
ws = WechatService.new
|
2016-08-14 15:25:46 +08:00
|
|
|
|
ws.binding_succ_notice(user.id, "您已成功绑定Trustie平台。", user.show_name+"("+user.login+")", Time.now.strftime("%Y-%m-%d"))
|
2016-06-20 14:39:20 +08:00
|
|
|
|
present status: 0, message: '您已成功绑定Trustie平台'
|
2016-06-17 18:18:03 +08:00
|
|
|
|
end
|
|
|
|
|
|
2014-12-10 16:23:56 +08:00
|
|
|
|
desc "注册用户"
|
2014-12-09 16:36:43 +08:00
|
|
|
|
params do
|
|
|
|
|
requires :login, type: String, desc: 'username'
|
|
|
|
|
requires :mail, type: String, desc: 'mail'
|
|
|
|
|
requires :password, type: String, desc: 'password'
|
|
|
|
|
end
|
|
|
|
|
post do
|
2016-06-29 21:09:49 +08:00
|
|
|
|
openid = session[:wechat_openid]
|
|
|
|
|
logger.debug "openid ============== #{openid}"
|
2016-08-12 09:23:09 +08:00
|
|
|
|
raise "无法获取到openid,请在微信中打开本页面" unless openid
|
2016-06-29 21:09:49 +08:00
|
|
|
|
|
2016-08-11 17:22:48 +08:00
|
|
|
|
uw = UserWechat.where(openid: openid).first
|
2016-08-13 14:39:15 +08:00
|
|
|
|
raise "此微信号已绑定用户(#{uw.user.login}), 不能重复绑定" if uw && uw.real?
|
|
|
|
|
us = UsersService.new
|
|
|
|
|
user = us.register params.merge(:password_confirmation => params[:password],
|
|
|
|
|
:should_confirmation_password => true)
|
|
|
|
|
raise user.errors.full_messages.first if user.new_record?
|
2016-08-14 12:29:10 +08:00
|
|
|
|
#自动激活
|
2016-08-14 13:24:07 +08:00
|
|
|
|
if Setting.self_registration != '3'
|
|
|
|
|
# user = automatically_register(user)
|
|
|
|
|
user.activate
|
|
|
|
|
user.last_login_on = Time.now
|
|
|
|
|
if user.save
|
|
|
|
|
UserStatus.create(:user_id => user.id, :changsets_count => 0, :watchers_count => 0)
|
|
|
|
|
end
|
|
|
|
|
end
|
2016-08-11 17:22:48 +08:00
|
|
|
|
|
2016-08-14 10:46:17 +08:00
|
|
|
|
if uw && !uw.real?
|
2016-08-14 09:38:47 +08:00
|
|
|
|
user.update_attributes(:lastname=>uw.user[:lastname])
|
2016-08-13 14:39:15 +08:00
|
|
|
|
uw.migrate_user(user)
|
|
|
|
|
else
|
2016-08-11 17:22:48 +08:00
|
|
|
|
UserWechat.create!(
|
2016-08-13 14:39:15 +08:00
|
|
|
|
openid: openid,
|
|
|
|
|
user: user
|
2016-08-11 17:22:48 +08:00
|
|
|
|
)
|
|
|
|
|
end
|
2016-06-29 21:09:49 +08:00
|
|
|
|
|
2016-07-15 10:26:37 +08:00
|
|
|
|
ws = WechatService.new
|
2016-08-14 15:25:46 +08:00
|
|
|
|
ws.binding_succ_notice(user.id, "您已成功绑定Trustie平台。", user.show_name+"("+user.login+")", Time.now.strftime("%Y-%m-%d"))
|
2014-12-10 17:29:39 +08:00
|
|
|
|
present :data, user, with: Mobile::Entities::User
|
|
|
|
|
present :status, 0
|
2014-11-27 19:43:04 +08:00
|
|
|
|
end
|
2014-12-09 15:16:47 +08:00
|
|
|
|
|
2015-01-06 16:59:22 +08:00
|
|
|
|
desc "显示用户"
|
|
|
|
|
params do
|
2015-02-06 14:29:42 +08:00
|
|
|
|
requires :id, type: Integer
|
2015-01-06 16:59:22 +08:00
|
|
|
|
end
|
2015-02-06 14:29:42 +08:00
|
|
|
|
route_param :id do
|
|
|
|
|
get do
|
|
|
|
|
us = UsersService.new
|
|
|
|
|
ue = us.show_user params
|
|
|
|
|
present :data, ue,with: Mobile::Entities::User
|
|
|
|
|
present :status, 0
|
|
|
|
|
end
|
2015-01-06 16:59:22 +08:00
|
|
|
|
end
|
2014-12-10 11:56:33 +08:00
|
|
|
|
|
2014-12-10 16:23:56 +08:00
|
|
|
|
desc "修改用户"
|
2014-12-10 11:56:33 +08:00
|
|
|
|
params do
|
2014-12-10 16:23:56 +08:00
|
|
|
|
requires :token, type: String
|
2014-12-10 11:56:33 +08:00
|
|
|
|
#optional :file, type: File, desc: 'avatar'
|
|
|
|
|
optional :occupation, type: String
|
|
|
|
|
optional :brief_introduction, type: String
|
|
|
|
|
optional :province, type: String
|
|
|
|
|
optional :city, type: String
|
|
|
|
|
optional :gender, type: Integer
|
|
|
|
|
end
|
|
|
|
|
put ':id' do
|
|
|
|
|
authenticate!
|
|
|
|
|
us = UsersService.new
|
2014-12-10 17:29:39 +08:00
|
|
|
|
ue = us.edit_user params.merge(id: current_user.id)
|
2015-01-06 16:51:44 +08:00
|
|
|
|
present :data, ue,with: Mobile::Entities::User
|
2014-12-10 17:29:39 +08:00
|
|
|
|
present :status, 0
|
2014-12-10 16:51:19 +08:00
|
|
|
|
end
|
|
|
|
|
|
2015-01-06 17:46:16 +08:00
|
|
|
|
desc '获取用户课程'
|
|
|
|
|
params do
|
2015-01-21 11:28:09 +08:00
|
|
|
|
optional :token, type: String
|
2015-01-06 17:46:16 +08:00
|
|
|
|
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
|
|
|
|
|
|
2014-12-10 16:51:19 +08:00
|
|
|
|
|
|
|
|
|
desc '修改密码'
|
|
|
|
|
params do
|
|
|
|
|
requires :token, type: String
|
|
|
|
|
requires :password, type:String , desc: '原密码'
|
|
|
|
|
requires :new_password, type: String, desc: '新密码'
|
|
|
|
|
end
|
|
|
|
|
post 'password' do
|
|
|
|
|
authenticate!
|
|
|
|
|
us = UsersService.new
|
2014-12-23 14:46:23 +08:00
|
|
|
|
user = us.change_password params.merge(current_user_id: current_user.id,
|
2014-12-23 10:16:23 +08:00
|
|
|
|
new_password_confirmation: params[:new_password])
|
2014-12-10 17:29:39 +08:00
|
|
|
|
present :data, user, with: Mobile::Entities::User
|
|
|
|
|
present :status, 0
|
2014-12-10 11:56:33 +08:00
|
|
|
|
end
|
|
|
|
|
|
2015-02-06 14:29:42 +08:00
|
|
|
|
desc "用户搜索"
|
2014-12-13 21:52:26 +08:00
|
|
|
|
params do
|
|
|
|
|
requires :name, type: String, desc: '用户名关键字'
|
2016-01-22 17:27:21 +08:00
|
|
|
|
requires :search_by, type: String,desc: '搜索依据:0 登录名,1 用户名,2 邮箱,3 登录名和姓名'
|
2015-05-13 09:56:34 +08:00
|
|
|
|
optional :is_search_assitant,type:Integer,desc:'是否搜索注册用户来作为助教'
|
2015-05-15 09:06:36 +08:00
|
|
|
|
optional :course_id,type:Integer,desc: '课程id,搜索注册用户不为该课程教师的其他用户'
|
2015-05-15 14:04:05 +08:00
|
|
|
|
optional :user_id,type:Integer,desc:'用户id'
|
2014-12-13 21:52:26 +08:00
|
|
|
|
end
|
2015-02-06 14:29:42 +08:00
|
|
|
|
get 'search/search_user' do
|
2014-12-13 21:52:26 +08:00
|
|
|
|
us = UsersService.new
|
|
|
|
|
user = us.search_user params
|
|
|
|
|
present :data, user, with: Mobile::Entities::User
|
|
|
|
|
present :status, 0
|
|
|
|
|
end
|
|
|
|
|
|
2015-05-20 17:27:17 +08:00
|
|
|
|
desc "用户留言"
|
|
|
|
|
params do
|
|
|
|
|
requires :token, type: String
|
|
|
|
|
requires :user_id, type: Integer,desc: '被留言的用户id'
|
2015-05-23 17:13:38 +08:00
|
|
|
|
requires :page,type:Integer,desc:'请求数据的页码'
|
2015-05-20 17:27:17 +08:00
|
|
|
|
end
|
|
|
|
|
get ':user_id/messages' do
|
|
|
|
|
us = UsersService.new
|
|
|
|
|
jours = us.get_all_messages params
|
|
|
|
|
present :data,jours,with:Mobile::Entities::Jours
|
|
|
|
|
present :status,0
|
|
|
|
|
end
|
|
|
|
|
|
2015-05-26 09:48:22 +08:00
|
|
|
|
desc "回复用户留言"
|
2015-05-20 17:27:17 +08:00
|
|
|
|
params do
|
|
|
|
|
requires :token, type: String
|
|
|
|
|
requires :user_id, type: Integer,desc: '被留言的用户id'
|
|
|
|
|
requires :content,type:String,desc:'留言内容'
|
2015-05-21 15:57:35 +08:00
|
|
|
|
requires :ref_user_id,type:Integer,desc:'被回复的用户id'
|
|
|
|
|
requires :parent_id,type:Integer,desc:'留言父id'
|
|
|
|
|
requires :ref_message_id,type:Integer,desc:'引用消息id'
|
2015-05-28 17:51:50 +08:00
|
|
|
|
optional :type,type:Integer,desc:'回复类型'
|
|
|
|
|
optional :course_id,type:Integer,desc:'课程id'
|
2015-05-20 17:27:17 +08:00
|
|
|
|
end
|
2015-05-26 09:48:22 +08:00
|
|
|
|
post ':user_id/reply_message' do
|
2015-05-20 17:27:17 +08:00
|
|
|
|
us = UsersService.new
|
2015-05-21 15:57:35 +08:00
|
|
|
|
jours = us.reply_user_messages params,current_user
|
2015-05-20 17:27:17 +08:00
|
|
|
|
present :status,0
|
|
|
|
|
end
|
|
|
|
|
|
2015-05-26 09:48:22 +08:00
|
|
|
|
desc "给用户留言"
|
|
|
|
|
params do
|
|
|
|
|
requires :token, type: String
|
|
|
|
|
requires :user_id, type: Integer,desc:'被留言的用户id'
|
|
|
|
|
requires :content, type: String,desc:'留言内容'
|
|
|
|
|
end
|
|
|
|
|
post ':user_id/leave_message' do
|
|
|
|
|
us = UsersService.new
|
|
|
|
|
us.leave_message params,current_user
|
|
|
|
|
present :data,0
|
|
|
|
|
end
|
2015-05-28 17:51:50 +08:00
|
|
|
|
|
|
|
|
|
desc "与我相关"
|
|
|
|
|
params do
|
|
|
|
|
requires :token, type: String
|
|
|
|
|
requires :page,type:Integer,desc:'页码'
|
|
|
|
|
end
|
|
|
|
|
get ':user_id/all_my_dynamic' do
|
|
|
|
|
us = UsersService.new
|
|
|
|
|
my_jours = us.reply_my_messages params,current_user
|
|
|
|
|
present :data,my_jours,with:Mobile::Entities::Jours
|
|
|
|
|
present :status,0
|
|
|
|
|
end
|
2016-09-06 14:41:22 +08:00
|
|
|
|
|
|
|
|
|
desc "我的资料"
|
|
|
|
|
|
|
|
|
|
params do
|
|
|
|
|
requires :token, type: String
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
get 'my_userinfo' do
|
|
|
|
|
authenticate!
|
|
|
|
|
present :data, current_user, with: Mobile::Entities::User
|
|
|
|
|
present :status, 0
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
desc "我的资料"
|
|
|
|
|
|
|
|
|
|
params do
|
|
|
|
|
requires :token, type: String
|
|
|
|
|
requires :nickname, type: String
|
|
|
|
|
requires :sex, type: Integer
|
|
|
|
|
requires :mail, type: String
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
post 'edit_userinfo' do
|
|
|
|
|
authenticate!
|
|
|
|
|
user = current_user
|
|
|
|
|
status = 0
|
|
|
|
|
message = ""
|
|
|
|
|
|
|
|
|
|
#昵称 不能超过30个字符
|
|
|
|
|
if params[:nickname].length > 30 then
|
|
|
|
|
message = "姓名不能超过30个字符!"
|
|
|
|
|
status = -1
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
if params[:mail].length > 60 then
|
|
|
|
|
message = "邮箱地址不能超过60个字符!"
|
|
|
|
|
status = -1
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
if !(params[:mail].match(/\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\z/i))
|
|
|
|
|
message = "请输入正确的邮箱地址!"
|
|
|
|
|
status = -1
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
if status == 0
|
|
|
|
|
# 修改邮箱的时候同步修改到gitlab
|
|
|
|
|
if user.mail != params[:mail]
|
|
|
|
|
g = Gitlab.client
|
|
|
|
|
begin
|
|
|
|
|
g.edit_user(user.gid, :email => params[:mail])
|
|
|
|
|
rescue
|
|
|
|
|
logger.error "sync user's email of gitlab failed!"
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
user.lastname = params[:nickname]
|
|
|
|
|
|
|
|
|
|
se = user.extensions
|
|
|
|
|
|
|
|
|
|
se.gender = params[:sex]
|
|
|
|
|
|
|
|
|
|
if user.save && se.save
|
|
|
|
|
status = 0
|
|
|
|
|
else
|
|
|
|
|
message = "保存数据失败!"
|
|
|
|
|
status = -1
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
if status == 0
|
|
|
|
|
present :data, current_user, with: Mobile::Entities::User
|
|
|
|
|
present :status, 0
|
|
|
|
|
else
|
|
|
|
|
present :status, -1
|
|
|
|
|
present :message, message
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
desc "解除绑定"
|
|
|
|
|
|
|
|
|
|
params do
|
|
|
|
|
requires :token, type: String
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
post 'unbind' do
|
|
|
|
|
authenticate!
|
|
|
|
|
|
|
|
|
|
us = UsersService.new
|
|
|
|
|
us.wechat_unbind uw
|
|
|
|
|
|
|
|
|
|
present :status, 0
|
|
|
|
|
end
|
|
|
|
|
|
2014-12-09 15:16:47 +08:00
|
|
|
|
end
|
2014-11-27 19:43:04 +08:00
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|