2016-04-08 17:33:00 +08:00
#coding=utf-8
2015-04-07 13:47:39 +08:00
# 数据库字段中带有m前缀和is_readed是二次开发添加, 之前的字段基本复用
# 注意reply_id 是提到人的id, 不是留言id, Base中叫做 at_user
class JournalsForMessage < ActiveRecord :: Base
2016-03-31 20:46:36 +08:00
require 'net/http'
require 'json'
2015-04-07 13:47:39 +08:00
include Redmine :: SafeAttributes
include UserScoreHelper
include ApplicationHelper
has_many_kindeditor_assets :assets , :dependent = > :destroy
safe_attributes " jour_type " , # 留言所属类型
" jour_id " , # 留言所属类型的id
" notes " , # 留言内容
" reply_id " , # 留言被回复留言者的用户id(用户a回复了用户b, 这是b的id, 用以查询谁给b留言了)
" status " , # 留言是否被查看(弃用)
" user_id " , # 留言者的id
" m_parent_id " , # 留言信息的父留言id
" is_readed " , # 留言是否已读
" m_reply_count " , # 留言的回复数量
2016-01-06 16:22:13 +08:00
" m_reply_id " , # 回复某留言的留言id(a留言回复了b留言, 这是b留言的id)
" is_comprehensive_evaluation " , # 1 教师评论、2 匿评、3 留言
2016-10-11 14:08:44 +08:00
" private " ,
" root_id "
2015-04-07 13:47:39 +08:00
acts_as_tree :foreign_key = > 'm_parent_id' , :counter_cache = > :m_reply_count , :order = > " #{ JournalsForMessage . table_name } .created_on ASC "
after_destroy :delete_kindeditor_assets
belongs_to :project ,
:foreign_key = > 'jour_id' ,
2015-11-26 16:43:10 +08:00
:conditions = > " #{ self . table_name } .jour_type = 'Project' " , :touch = > true
2015-04-07 13:47:39 +08:00
belongs_to :course ,
2015-11-30 12:55:19 +08:00
:foreign_key = > 'jour_id' , :touch = > true
2015-04-07 13:47:39 +08:00
belongs_to :jour , :polymorphic = > true
belongs_to :user
belongs_to :homework_attach
2015-05-27 14:58:55 +08:00
belongs_to :student_works_score
2015-04-07 13:47:39 +08:00
belongs_to :at_user , :class_name = > " User " , :foreign_key = > 'reply_id'
acts_as_event :title = > Proc . new { | o | " #{ l ( :label_my_message ) } " } ,
:datetime = > Proc . new { | o | o . updated_on } ,
:author = > Proc . new { | o | o . user } ,
:description = > Proc . new { | o | o . notes } ,
:type = > Proc . new { | o | o . jour_type } ,
:url = > Proc . new { | o |
if o . jour . kind_of? Project
{ :controller = > 'projects' , :action = > 'feedback' , :id = > o . jour , :r = > o . id , :anchor = > " word_li_ #{ o . id } " }
elsif o . jour . kind_of? Course
{ :controller = > 'courses' , :action = > 'feedback' , :id = > o . jour , :r = > o . id , :anchor = > " word_li_ #{ o . id } " }
end
}
acts_as_activity_provider :author_key = > :user_id ,
:timestamp = > " #{ self . table_name } .updated_on " ,
:find_options = > { :include = > :project }
acts_as_activity_provider :type = > 'course_journals_for_messages' ,
:author_key = > :user_id ,
2015-04-16 10:26:03 +08:00
:permission = > :view_course_journals_for_messages ,
2015-04-07 13:47:39 +08:00
:timestamp = > " #{ self . table_name } .updated_on " ,
:find_options = > { :include = > :course }
2015-04-28 12:21:35 +08:00
acts_as_attachable
2015-04-07 13:47:39 +08:00
has_many :acts , :class_name = > 'Activity' , :as = > :act , :dependent = > :destroy
2015-10-13 16:51:44 +08:00
has_many :principal_acts , :class_name = > 'PrincipalActivity' , :as = > :principal_act , :dependent = > :destroy
2015-08-11 15:54:05 +08:00
# 课程动态
has_many :course_acts , :class_name = > 'CourseActivity' , :as = > :course_act , :dependent = > :destroy
2016-12-22 10:01:37 +08:00
# 竞赛动态
has_many :contest_acts , :class_name = > 'ContestActivity' , :as = > :contest_act , :dependent = > :destroy
2015-08-18 15:27:16 +08:00
# 消息关联
has_many :course_messages , :class_name = > 'CourseMessage' , :as = > :course_message , :dependent = > :destroy
2016-12-22 10:01:37 +08:00
has_many :contest_messages , :class_name = > 'ContestMessage' , :as = > :contest_message , :dependent = > :destroy
2015-08-21 17:00:17 +08:00
has_many :user_feedback_messages , :class_name = > 'UserFeedbackMessage' , :as = > :journals_for_message , :dependent = > :destroy
2015-04-07 13:47:39 +08:00
2015-12-17 15:14:52 +08:00
has_many :at_messages , as : :at_message , dependent : :destroy
2016-09-23 16:44:49 +08:00
has_many :praise_tread , as : :praise_tread_object , dependent : :destroy
has_one :praise_tread_cache , as : :object , dependent : :destroy
2015-12-17 15:14:52 +08:00
2015-04-27 17:25:42 +08:00
validates :notes , presence : true , if : :is_homework_jour?
2017-01-11 10:16:25 +08:00
after_create :act_as_course_activity , :act_as_course_message , :act_as_contest_activity ,
2016-03-11 18:50:37 +08:00
act_as_at_message ( :notes , :user_id ) , :act_as_user_feedback_message ,
2017-01-18 14:13:25 +08:00
:act_as_principal_activity , :act_as_contest_message
2017-02-10 17:36:23 +08:00
after_create :act_as_student_score
2016-01-26 11:17:55 +08:00
#after_update :update_activity
2016-11-11 10:37:20 +08:00
# after_destroy :reset_counters!
2016-12-16 11:42:52 +08:00
# after_save :be_user_score
2016-03-08 17:38:38 +08:00
after_destroy :down_user_score , :down_course_score
2015-04-07 13:47:39 +08:00
# default_scope { where('m_parent_id IS NULL') }
2016-01-12 15:53:15 +08:00
#动态的更新
def update_activity
update_course_activity ( self . class , self . id )
update_user_activity ( self . class , self . id )
update_forge_activity ( self . class , self . id )
update_org_activity ( self . class , self . id )
update_principal_activity ( self . class , self . id )
end
2015-04-07 13:47:39 +08:00
def self . create_by_user? user
if user . anonymous?
return false
else
return true
end
end
def self . remove_by_user? user
if ( self . user == user ||
( self . jour . kind_of? ( User ) && self . jour == user )
)
true
else
false
end
end
def self . delete_message ( message_id )
self . find ( message_id ) . destroy
# self.destroy_all "id = #{message_id}"
end
2015-04-27 17:25:42 +08:00
def is_homework_jour?
self . jour_type != " HomeworkAttach "
end
2015-04-07 13:47:39 +08:00
def reference_user
User . find ( reply_id )
end
def delete_by_user? user
# 用户可删除自己的留言
if self . user . id == user . id || user . admin?
return true
else
return false
end
end
def self . reference_message ( user_id )
@user = User . find ( user_id )
message = JournalsForMessage . find_by_sql ( " select * from journals_for_messages where reply_id = #{ @user . id }
or ( jour_type = 'Bid' and jour_id in ( select id from bids where author_id = #{@user.id}))")
message
end
def act_as_activity
if self . jour_type == 'Principal'
unless self . user_id == self . jour . id && self . user_id != self . reply_id && self . reply_id != 0
# self.acts << Activity.new(:user_id => self.user_id)
self . acts << Activity . new ( :user_id = > self . jour_id )
end
elsif self . jour_type == 'Project'
self . acts << Activity . new ( :user_id = > self . reply_id )
elsif self . jour_type == 'Course'
self . acts << Activity . new ( :user_id = > self . reply_id )
else
end
end
2015-10-13 16:51:44 +08:00
#用户动态公共表记录
def act_as_principal_activity
2015-11-09 16:08:15 +08:00
if self . jour_type == 'Principal' && self . m_parent_id . nil?
self . principal_acts << PrincipalActivity . new ( :user_id = > self . user_id , :principal_id = > self . jour_id )
2015-10-14 11:38:16 +08:00
end
2015-10-13 16:51:44 +08:00
end
2015-04-07 13:47:39 +08:00
def reset_counters!
2016-11-04 11:30:11 +08:00
# self.class.reset_counters!(self)
2015-04-07 13:47:39 +08:00
end
def self . reset_counters! journals_for_messages
# jfm_id = journals_for_messages.id.to_i
count = find_all_by_m_parent_id ( journals_for_messages . m_parent_id ) . count #(SELECT COUNT(*) FROM #{JournalsForMessage.table_name} WHERE m_parent_id = #{jfm_id} )
update_all ( " m_reply_count = #{ count . to_i } " , [ " id = ? " , journals_for_messages . m_parent_id ] )
end
#如果是在项目中留言则返回该项目否则返回nil - zjc
def project
if self . jour_type == 'Project'
Project . find ( self . jour_id )
else
nil
end
end
# 更新用户分数 -by zjc
def be_user_score
#新建了留言回复
if self . reply_id != 0
#协同得分加分
UserScore . joint ( :reply_message , self . user , User . find ( self . reply_id ) , self , { journals_for_messages_id : self . id } )
update_replay_for_message ( self . user , 1 )
if self . jour_type == " Project "
update_replay_for_message ( self . user , 2 , self . jour )
end
end
end
2016-03-08 17:38:38 +08:00
2015-04-07 13:47:39 +08:00
# 更新用户分数 -by zjc
def down_user_score
#删除了留言回复
if self . reply_id != 0
#协同得分减分
UserScore . joint ( :reply_message_delete , self . user , User . find ( self . reply_id ) , { journals_for_messages_id : self . id } )
update_replay_for_message ( self . user , 1 )
if self . jour_type == " Project "
update_replay_for_message ( self . user , 2 , self . jour )
end
end
end
# Time 2015-04-01 14:15:06
# Author lizanle
# Description 删除对应课程留言的图片资源
def delete_kindeditor_assets
delete_kindeditor_assets_from_disk self . id , 7
end
2015-08-11 15:54:05 +08:00
#课程动态公共表记录
def act_as_course_activity
2015-09-25 16:29:47 +08:00
if self . jour_type == 'Course' && self . m_parent_id . nil?
2015-08-11 15:54:05 +08:00
self . course_acts << CourseActivity . new ( :user_id = > self . user_id , :course_id = > self . jour_id )
end
end
2015-08-18 15:27:16 +08:00
2017-01-11 10:16:25 +08:00
#竞赛动态公共表记录
def act_as_contest_activity
if self . jour_type == 'Contest' && self . m_parent_id . nil?
self . contest_acts << ContestActivity . new ( :user_id = > self . user_id , :contest_id = > self . jour_id )
end
end
2015-09-18 10:05:26 +08:00
# 课程/作品回复 留言消息通知
2015-08-18 15:27:16 +08:00
def act_as_course_message
if self . jour_type == 'StudentWorksScore'
if self . user_id != self . jour . user_id
2015-08-19 17:29:05 +08:00
self . course_messages << CourseMessage . new ( :user_id = > self . jour . user_id , :course_id = > self . jour . student_work . homework_common . course . id , :viewed = > false )
end
end
2015-09-18 10:05:26 +08:00
# 课程留言
2015-09-18 13:03:35 +08:00
if self . jour_type == 'Course'
receivers = [ ]
teachers = [ ]
# 获取课程的老师
2015-09-18 10:05:26 +08:00
self . jour . members . each do | m |
2015-09-18 13:03:35 +08:00
if m . user . allowed_to? ( :as_teacher , self . jour )
teachers << m
end
end
if self . reply_id == 0 # 主留言,即不是回复某条留言
teachers . each do | teacher |
if teacher . user_id != self . user_id
receivers << teacher . user_id
end
2015-09-18 10:05:26 +08:00
end
2015-09-18 13:03:35 +08:00
else # 留言回复
reply_to = User . find ( self . reply_id )
if self . user_id != self . reply_id # 添加我回复的那个人
receivers << reply_to . id
end
# 给老师发送。 过滤条件:老师自己给自己发;回复对象为老师则排除改老师
teachers . each do | teacher |
if teacher . user_id != self . user_id && self . reply_id != teacher . user_id
receivers << teacher . user_id
end
end
end
receivers . each do | r |
self . course_messages << CourseMessage . new ( :user_id = > r , :course_id = > self . jour . id , :viewed = > false )
2015-09-18 10:05:26 +08:00
end
end
2016-05-05 10:52:54 +08:00
if self . jour_type == 'HomeworkCommon'
2016-05-12 14:13:34 +08:00
if self . m_parent_id . nil?
if self . user_id != self . jour . user_id
self . course_messages << CourseMessage . new ( :user_id = > self . jour . user_id , :course_id = > self . jour . course . id , :viewed = > false )
2016-06-02 10:39:11 +08:00
# count = ShieldWechatMessage.where("container_type='User' and container_id=#{self.jour.user_id} and shield_type='Course' and shield_id=#{self.jour.course_id}").count
# if count == 0
# ws = WechatService.new
# #content = truncate(strip_tags(self.notes.to_s), length: 200)
# content = strip_html self.notes.html_safe, 200
# ws.comment_template self.jour.user_id, "homework", self.jour_id, "#{l(:label_homework_comment_template)}", self.user.try(:realname), format_time(self.created_on), content
# end
2016-05-12 14:13:34 +08:00
end
2016-05-17 15:33:16 +08:00
else
if self . user_id != self . parent . user_id
self . course_messages << CourseMessage . new ( :user_id = > self . parent . user_id , :course_id = > self . jour . course . id , :viewed = > false )
2016-06-02 10:39:11 +08:00
# count = ShieldWechatMessage.where("container_type='User' and container_id=#{self.parent.user_id} and shield_type='Course' and shield_id=#{self.jour.course_id}").count
# if count == 0
# ws = WechatService.new
# #content = truncate(strip_tags(self.notes.to_s), length: 200)
# content = strip_html self.notes.html_safe, 200
# ws.comment_template self.parent.user_id, "homework", self.jour_id, "#{l(:label_new_second_comment_template)}", self.user.try(:realname), format_time(self.created_on), content
# end
2016-05-17 15:33:16 +08:00
end
2016-05-12 14:13:34 +08:00
end
2016-03-31 20:46:36 +08:00
end
2015-08-19 17:29:05 +08:00
end
2016-03-11 18:50:37 +08:00
2015-08-19 17:29:05 +08:00
# 用户留言消息通知
def act_as_user_feedback_message
# 主留言
2016-04-14 10:47:53 +08:00
ws = WechatService . new
2015-08-19 17:29:05 +08:00
if self . jour_type == 'Principal'
2015-08-31 16:41:52 +08:00
receivers = [ ]
if self . reply_id == 0
if self . user_id != self . jour_id # 过滤自己给自己的留言消息
receivers << self . jour
2016-04-20 10:44:54 +08:00
content = strip_html self . notes , 200
2016-06-02 10:39:11 +08:00
ws . journal_notice self . jour_id , " journal_for_message " , self . id , " #{ l ( :label_new_journals_template ) } " , self . user . show_name , format_time ( self . created_on ) , content
2015-08-20 09:25:48 +08:00
end
2015-08-31 16:41:52 +08:00
else # 留言回复
reply_to = User . find ( self . reply_id )
if self . user_id != self . reply_id # 添加我回复的那个人
receivers << reply_to
end
if self . user_id != self . parent . jour_id && self . reply_id != self . parent . jour_id # 给东家发信息,如果回复的对象是东家则不发
receivers << self . parent . jour
end
2016-06-02 10:39:11 +08:00
#content = strip_html self.notes, 200
#ws.comment_template self.reply_id, "journal_for_message", self.parent.id, "#{l(:label_journals_comment_template)}", self.user.try(:realname), format_time(self.created_on), content
2015-08-31 16:41:52 +08:00
end
receivers . each do | r |
self . user_feedback_messages << UserFeedbackMessage . new ( :user_id = > r . id , :journals_for_message_id = > self . id , :journals_for_message_type = > " Principal " , :viewed = > false )
end
2015-08-18 15:27:16 +08:00
end
end
2015-11-26 18:22:03 +08:00
2017-01-18 14:13:25 +08:00
# 竞赛留言消息通知
def act_as_contest_message
# 主留言
if self . jour_type == 'Contest'
if self . m_parent_id . nil?
receivers = self . jour . contest_members . select { | cm | cm . roles . to_s . include? ( " ContestManager " ) && cm . user_id != self . user_id }
receivers . each do | r |
self . contest_messages << ContestMessage . new ( :user_id = > r . user_id , :contest_id = > self . jour . id , :viewed = > false )
end
else # 留言回复
if self . user_id != self . reply_id # 添加我回复的那个人
self . contest_messages << ContestMessage . new ( :user_id = > self . reply_id , :contest_id = > self . jour . id , :viewed = > false )
end
end
end
end
2016-03-05 03:13:58 +08:00
# 课程成员得分(活跃度)
2015-11-26 18:22:03 +08:00
def act_as_student_score
2016-03-03 18:51:28 +08:00
if self . jour_type == " Course "
2016-03-08 17:38:38 +08:00
course_member_score ( self . jour_id , self . user_id , " Course " )
2016-03-03 18:51:28 +08:00
elsif self . jour_type == " HomeworkCommon "
2016-03-04 11:36:34 +08:00
course_member_score ( self . jour . course_id , self . user_id , " HomeworkCommon " )
2015-11-26 18:22:03 +08:00
end
end
2016-03-08 17:38:38 +08:00
# 删除操作的时候相应扣掉回复数
def down_course_score
if self . jour_type == " Course "
down_course_score_num ( self . jour_id , self . user_id , " Course " )
elsif self . jour_type == " HomeworkCommon "
down_course_score_num ( self . jour . course_id , self . user_id , " HomeworkCommon " )
end
end
2016-06-07 16:02:00 +08:00
def creator_user
self . user
end
def created_time
self . created_on
end
def content_detail
self . notes
end
2016-11-24 14:30:24 +08:00
def set_children_readed_delay
# fetch_user_leaveWord_reply(self).update_all(:is_readed => true, :status => false)
end
2015-04-07 13:47:39 +08:00
end