#coding=utf-8 class UsersService include ApplicationHelper include AccountHelper include AvatarHelper include CoursesHelper include ApiHelper include WordsHelper #将用户注册的功能函数写这里 #参数约定 #成功返回注册后的User实例,失败直接抛异常 # return: # status: 1 表示成功, -1 表示金币不足 def consume_score params, current_user user_score = current_user.grade consume_score = parmas[:score] record = Grade.where(:container_id => params[:container_id], :container_type => params[:container_type], :user_id => current_user.id).first return {status: 1, message: "查看成功!"} if record if user_score < consume_score {status: -1, message: "本操作需要扣除#{ consume_score }金币,您的金币不够了"} else current_user.update_column(:grade, current_user.grade - consume_score) Grade.create(:container_id => params[:container_id], :container_type => params[:container_type], :score => -params[:score], :user_id => current_user.id) {status: 1, message: "查看成功!"} end end ## 获取最新的消息 def get_tidings(params,current_user) current_user.tidings.course_tiding.order('id desc').page(params[:page]||1).per(20) end def login params, current_user login = params[:username].strip password = params[:password] # 验证用户名密码是否正确 user, last_login_on = User.try_to_login(login, password) if user.blank? return {:status => -2, :message => "无效的用户名或密码"} else Rails.logger.info("successful_authentication, user is #{user.try(:login)}") # 登录重置session;重新开启session有效时间等 if user && user.is_a?(User) User.current = user # session[:user_id] = user.id # session[:ctime] = Time.now.utc.to_i # session[:atime] = Time.now.utc.to_i else User.current = User.anonymous end # self.logged_user = user # generate a key and set cookie if autologin if params[:autologin] && Setting.autologin? # set_autologin_cookie(user) end # 记录用户登录行为 UserActions.create(:action_id => User.current.id, :action_type => "PhoneLogin", :user_id => User.current.id) return user end end # 生成邀请码 CODES = %W(0 1 2 3 4 5 6 7 8 9) def generate_user_login type code = CODES.sample(8).join code = type + code.to_s return generate_user_login(type) if User.where(login: code).present? code end # 关注 def watch params, current_user s = WatchesService.new s.watch params.merge(:current_user_id => current_user.id) return {:status => 1, :message => "success"} end # 取消关注 def unwatch params, current_user s = WatchesService.new s.unwatch params.merge(:current_user_id => current_user.id) return {:status => 1, :message => "success"} end def register(params) @user = User.new @user.admin = false @user.register if params[:phone] =~ /^[a-zA-Z0-9]+([._\\]*[a-z0-9])*@([a-z0-9]+[-a-z0-9]*[a-z0-9]+.){1,63}[a-z0-9]+$/ login_pre = 'm' @user.mail = params[:phone] elsif params[:phone] =~ /^1\d{10}$/ login_pre = 'p' @user.phone = params[:phone] else login_pre = 'w' end @user.login = generate_user_login login_pre password = params[:password] || params[:mail_password] password_confirmation = params[:password] || params[:mail_password] should_confirmation_password = params[:should_confirmation_password] if !password.blank? && !password_confirmation.blank? && should_confirmation_password @user.password, @user.password_confirmation = password, password_confirmation elsif !password.blank? && !should_confirmation_password @user.password = password else @user.password = "" end =begin if params[:mail] case Setting.self_registration when '1' @user = email_activation_register(@user) when '3' @user = automatically_register(@user) else @user = administrator_manually__register(@user) end else @user = automatically_register(@user) end =end @user = automatically_register(@user) if @user.id != nil ue = @user.user_extensions ||= UserExtensions.new 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 # 自动注册功能 FOR:邮件邀请 def register_auto(login, mail, password, first_name, last_name, gender) mail_notification = "day" @user = User.new @user.admin = false @user.register @user.login = login @user.mail = mail @user.firstname = first_name @user.lastname = last_name @user.mail_notification = mail_notification password_confirmation = password should_confirmation_password = true if !password.blank? && !password_confirmation.blank? && should_confirmation_password @user.password, @user.password_confirmation = password, password_confirmation elsif !password.blank? && !should_confirmation_password @user.password = password else @user.password = "" end @user = automatically_register_lock(@user) if @user.id != nil ue = @user.user_extensions ||= UserExtensions.new ue.gender = gender ue.user_id = @user.id ue.save end @user end #显示用户 #id用户id def show_user(params) if params[:id].present? User.find(params[:id]) elsif params[:login].present? User.find_by_login(params[:login]) end end #忘记密码 def lost_password params user = ::User.find_by_mail(params[:mail].to_s) # user not found or not active unless user && user.active? raise l(:notice_account_unknown_email,:locale => 'zh') end # user cannot change its password unless user.change_password_allowed? raise l(:notice_can_t_change_password,:locale => user.language) return end # create a new token for password recovery token = Token.new(:user => user, :action => "recovery") if token.save Mailer.run.lost_password(token) return l(:notice_account_lost_email_sent,:locale => user.language) end end #编辑用户 #gender 1:female 0:male 其他:male def edit_user params @user = User.find(params[:id]) fileio = params[:file] # @se = @user.extensions # if @user.user_extensions.identity == 0 || @user.user_extensions.identity == 1 # @se.school_id = params[:occupation] # elsif @user.user_extensions.identity == 3 # @se.occupation = params[:occupation] # elsif @user.user_extensions.identity == 2 # @user.firstname = params[:occupation] # end # @se.brief_introduction = params[:brief_introduction] # @se.gender = params[:gender] # @se.location = params[:province] if params[:province] # @se.location_city = params[:city] if params[:city] # raise @se.errors.full_message unless @se.save unless fileio.nil? file = fileio[:tempfile] diskfile=disk_filename(@user.class.to_s, @user.id) @image_file = fileio[:name] @urlfile='/' << File.join("images", "avatars", avatar_directory(@user.class.to_s), avatar_filename(@user.id, @image_file)) path = File.dirname(diskfile) unless File.directory?(path) FileUtils.mkdir_p(path) end File.rename(file.path, @urlfile) begin f = Magick::ImageList.new(diskfile) # gif格式不再做大小处理 if f.format != 'GIF' width = 300.0 proportion = (width/f[0].columns) height = (f[0].rows*proportion) f.resize_to_fill!(width, height) f.write(diskfile) end rescue Exception => e logger.error "[Error] avatar : users_service#edit_user ===> #{e}" end end #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} @user end # 获取某个用户的所有留言信息 def get_all_messages params user = User.find(params[:user_id]) jours = user.journals_for_messages.where('m_parent_id IS NULL').order('created_on DESC').page(params[:page] || 1).per(10) jours.update_all(:is_readed => true, :status => false) jours.each do |journal| fetch_user_leaveWord_reply(journal).update_all(:is_readed => true, :status => false) end jours end # 回复用户 def reply_user_messages params,current_user user = User.find(params[:user_id]) m_parent_id = params[:parent_id] author_id = current_user.id reply_id = params[:ref_user_id] ref_message_id = params[:ref_message_id] content = params[:content] options = {:user_id => author_id, # 作者id :status => true, :m_parent_id => m_parent_id,# 父留言id :m_reply_id => ref_message_id, # 子留言 id :reply_id => reply_id, # 被留言用户id :notes => content, :is_readed => false} if(params[:type] == 1) user.add_jour(nil, nil,nil,options) elsif(params[:type] == 2) Course.find(params[:course_id]).journals_for_messages.build(options).save! unless params[:course_id].nil? else end end # 给用户留言 def leave_message params,current_user obj = User.find(params[:user_id]).add_jour(current_user, params[:content], 0) obj end #关注列表 def user_watcher params @user = User.find(params[:id]) User.watched_by(@user.id) end #用户课程列表 def current_courses params, current_user limit = params[:limit]||5 page = params[:page].to_i offset = (page-1) * limit courses = Course.find_by_sql("SELECT c.* FROM courses c, members m, member_roles mr WHERE m.course_id = c.id AND m.id=mr.member_id AND mr.role_id in (3,7,9,10) AND m.user_id=#{current_user.id} AND c.is_delete = 0 order by id desc limit #{limit} offset #{offset} ") # 如果还没有课程则显示示例课堂 courses = Course.where(:id => 1309) if courses.count == 0 course_list = [] courses.each do |course| teacher_ids = Member.find_by_sql("SELECT m.user_id FROM `member_roles` mr, users, `members` m where m.course_id=#{course.id} and m.user_id = users.id and users.status = 1 and m.id=mr.member_id and mr.role_id in ('3','7','9')").map(&:user_id) is_teacher = current_user.admin? || teacher_ids.include?(current_user.id) course_list << {:course => course, :is_teacher => is_teacher } end return course_list end #修改密码 def change_password params ActiveRecord::Base.transaction do @current_user = User.find(params[:current_user_id]) if @current_user.check_password?(params[:password]) @current_user.password, @current_user.password_confirmation = params[:new_password], params[:new_password_confirmation] @current_user.save # 修改密码同步gitlab密码修改 unless @current_user.gid.nil? begin g = Gitlab.client g.edit_user(@current_user.gid, :password => params[:new_password]) rescue Exception => e Rails.logger.error "change users password failed! ===> #{e.message}" end end #raise @current_user.errors.full_message #return @current_user else if params[:password].present? raise l(:notice_account_wrong_password,:locale => 'zh') else if params[:new_password].strip != "" && params[:new_password_confirmation].strip != "" @current_user.password, @current_user.password_confirmation = params[:new_password], params[:new_password_confirmation] @current_user.save unless @current_user.gid.nil? begin g = Gitlab.client g.edit_user(@current_user.gid, :password => params[:new_password]) rescue Exception => e Rails.logger.error "change users password failed! ===> #{e}" end end end end end @current_user end end #搜索用户 def search_user params status = params[:status] || 1 has = { "show_changesets" => true } scope = User.logged.status(status) search_by = params[:search_by] ? params[:search_by] : "0" if params[:is_search_assitant].nil? #modify by yutao 2015/5/18 没有params[:user_id]参数时去掉"id not in (?)"条件(bug:#2270) start #say by yutao: params[:user_id]这个是指谁发起的搜索么? 如果是 这个值貌似应该从session获取 怪怪的赶脚-_-! if params[:name].present? if !params[:user_id].nil? watcher = User.watched_by(params[:user_id]) watcher.push(params[:user_id]) scope = scope.where("id not in (?)",watcher) end #scope = scope.like(params[:name],search_by) scope = scope.where("( LOWER(login) LIKE ? or LOWER(concat(lastname, firstname)) LIKE ? or LOWER(mail) LIKE ? )", "%#{params[:name]}%","%#{params[:name]}%","%#{params[:name]}%") end #modify by yutao 2015/5/18 没有params[:user_id]参数时去掉"id not in (?)"条件 end else teachers = searchTeacherAndAssistant(Course.find(params[:course_id])) scope = scope.where("id not in (?)",teachers.map{|t| t.user_id}).like(params[:name],search_by) if params[:name].present? end scope end # 课程留言中与我相关的回复 def my_course_messages params,current_user #找到我所有的课程 @user = current_user if !current_user.admin? && !@user.active? raise '404' return end if current_user == @user || current_user.admin? membership = @user.coursememberships.all end # membership.sort! {|older, newer| newer.created_on <=> older.created_on } message_list = [] membership.each do |mp| #课程轮询找到与我相关的回复 message_list << mp.course.journals_for_messages.where("reply_id = ?",current_user.id) end message_list end # 获取与我相关的留言:我的留言,回复我的留言 def my_personal_messages params,current_user jours = current_user.journals_for_messages.where('m_parent_id is null or reply_id = ?',current_user.id) jours.update_all(:is_readed => true, :status => false) jours end # 所有的与我相关 def reply_my_messages params,current_user jours = my_personal_messages params,current_user jours1 = my_course_messages params,current_user my_jours = [] my_jours << jours << jours1 my_jours.flatten!.sort! {|older, newer| newer.created_on <=> older.created_on } my_jours_arr = Kaminari.paginate_array(my_jours, total_count: my_jours.count).page(params[:page] || 1).per(10) my_jours_arr end def wechat_unbind uw user = uw.user #发重新绑定的微信模版消息 type = "login" title = "尊敬的用户,您已解除绑定。" key1 = "个人原因" remark = "点击进入重新绑定。" ws = WechatService.new ws.rebind_notice user.id, type, user.id, title, key1,format_time(Time.now), remark uw.user_id = nil uw.delete end private def set_autologin_cookie(user) token = Token.get_or_create_permanent_login_token(user) cookie_options = { :value => token.value, :expires => 1.month.from_now, :path => (Redmine::Configuration['autologin_cookie_path'] || '/'), :secure => (Redmine::Configuration['autologin_cookie_secure'] ? true : false), :httponly => true } if Redmine::Configuration['cookie_domain'].present? cookie_options = cookie_options.merge(domain: Redmine::Configuration['cookie_domain']) end cookies[autologin_cookie_name] = cookie_options end end