/** * 聊天组模型。 */ "use strict"; let BaseModel = require('./base.model'); let log = require("../util/log.js"); let ModelUtil = require('../util/model.util'); //let getui = require('getui'); let Patient = new require("../models/user/patient"); let Doctor = new require('../models/user/doctor'); let GroupRepo = require('../repository/mysql/group.repo'); let GroupMsgRepo = require('../repository/mysql/group.msg.repo'); let StatsRepo = require("../repository/mysql/stats.msg.repo"); let ObjectUtil = require("../util/object.util.js"); const GROUP_TYPES = require('../include/commons').GROUP_TYPE; const MAX_INT = require('../include/commons').MAX_INT; class GroupMessage extends BaseModel { constructor() { super(); } /** * 发送消息。 * * @param message */ sendMessage(message) { let self = this; GroupRepo.isGroupMember(message.group, message.groupType, message.from, function (err, result) { if (err) { ModelUtil.emitError(self.eventEmitter, 'Check group member failed', err); return; } if (result.length == 0) { ModelUtil.emitDataNotFound(self.eventEmitter, 'Member with id "' + message.from + '" is not in group "' + message.group + '"'); return; } // 保存群组消息 GroupMsgRepo.save(message.from, message.group, message.at, message.contentType, message.content, function (err, insertedRow) { if (err) { ModelUtil.emitError(self.eventEmitter, 'Save group message failed', err); return; } GroupMsgRepo.findOneMessage(insertedRow.insertId, function (err, groupMsg) { if (err) { ModelUtil.emitError(self.eventEmitter, 'Save group message success, but return this message failed', err); return; } // 关闭网络连接后执行后续操作 let feedback = Doctor.fillMessages(groupMsg); ModelUtil.emitOK(self.eventEmitter, feedback); // 推送通知消息给群组成员 GroupRepo.getMembers(message.group, message.groupType, function (err, members) { if (err) { log.error('Get group members failed: ', err); return; } if (members.length == 0) { log.warn('No members in group ', message.group, message.groupType === GROUP_TYPES.AdminTeam ? " of admin team." : "of discussion group."); return; } // 逐个推送通知,患者与医生推送方式不一样 for (let i = 0; i < members.length; i++) { let member = members[i]; if (member.user_id === message.from) continue; (function (userId) { Patient.isPatientCode(userId, function () { let msg = { from: message.from, to: userId, contentType: message.contentType, content: message.content, msgId: groupMsg[0].msg_id, group: message.group }; new Patient().pushGroupMessage(msg); }, function () { let msg = { from: message.from, to: userId, contentType: message.contentType, content: message.content, msgId: groupMsg[0].msg_id, group: message.group }; Doctor.pushMessage(msg, 'group_msg'); // 更新用户组内消息摘要 let at = message.at == userId ? 1 : 0; StatsRepo.updateGroupChatSummary(userId, message.group, message.from, at, message.contentType, message.content, true, function (err, result) { if (err) log.error(err); }); }); })(member.user_id); } }); }); // 更新组内统计信息 StatsRepo.updateGroupChatSummary(message.from, message.group, message.from, 0, message.contentType, message.content, false, function (err, result) { if (err) log.error(err); }); }); }); } /** * 获取组消息。 */ getMessages(groupId, memberId, contentType, msgStartId, msgEndId, count) { let self = this; GroupMsgRepo.findAllMessages(groupId, !contentType ? "1,2,3,5,6" : contentType, msgStartId, msgEndId, count, function (err, rows) { if (err) { ModelUtil.emitError(self.eventEmitter, 'Get group message failed', err); return; } // 先给客户端返回数据 let messages = Doctor.fillMessages(rows); ModelUtil.emitOK(self.eventEmitter, messages); // 清空统计信息 StatsRepo.clearGroupChatSummary(memberId, groupId, function (err, result) { if (err) console.log(err); }); }); } /** * 获取组内未读消息。 * @param groupId */ getUnreadMessages(groupId, memberId) { let self = this; StatsRepo.getGroupChatSummary(memberId, groupId, function (err, summary) { if (err) { ModelUtil.emitError(self.eventEmitter, "Get unread group messages failed", err); return; } let messages = {startId: 0, count: 0, records: []}; if (summary.length == 0 || summary[0].new_msg_count === 0) { ModelUtil.emitOK(messages); return; } messages.count = summary[0].new_msg_count; GroupMsgRepo.findUnread(groupId, MAX_INT, messages.count, function (err, rows) { if (err) { ModelUtil.emitError(self.eventEmitter, "Get unread group messages failed", err); return; } let feedback = Doctor.fillMessages(rows); ModelUtil.emitOK(feedback); }); } ) ; } /** * 获取未读消息数量。 * * @param memberId */ getUnreadMessageCount(memberId) { let self = this; StatsRepo.getGroupChatAllUnReadCount(memberId, function (err, result) { if (err) { ModelUtil.emitError(self.eventEmitter, 'Get all unread messages failed', err); return; } let data = { userId: memberId, messageType: 2, newMessageCount: 0 }; if (result.length > 0) { for (let index = 0; index < result.length; index++) { data.newMessageCount += result[index].new_msg_count; } } ModelUtil.emitOK(self.eventEmitter, data); }); } /** * 获取特定群组消息统计情况. * * @param groupId * @param memberId */ getChatSummary(groupId, memberId) { let self = this; StatsRepo.getGroupChatSummary(memberId, groupId, function (err, result) { if (err) { ModelUtil.emitError(self.eventEmitter, 'Get group stats failed', err); return; } let data = { userId: userId, from: "", groupId: groupId, atMe: 0, lastContentType: 1, lastContent: "", newMessageCount: 0, timestamp: 0 }; if (result.length > 0) { let row = result[0]; data.from = row.from_uid; data.groupId = row.gid; data.atMe = row.at_me; data.lastContentType = row.last_content_type; data.lastContent = row.lastContent; data.newMessageCount = row.new_msg_count; data.timestamp = ObjectUtil.timestampToLong(row.timestamp) } ModelUtil.emitOK(self.eventEmitter, data); }); } /** * 获取成员头像。 * * @param groups 要获取的组ID列表。 */ getMemberAvatars(groups) { let self = this; let avatars = []; GroupRepo.getMembersAvatar(groups, function (err, members) { if (err) { ModelUtil.emitError(self.eventEmitter, "Get group member's avatar list failed", err); return; } let lastGroup; let lastGroupCode = ''; for (let i = 0; i < members.length; ++i) { let member = members[i]; let groupCode = member.g_code; if (lastGroupCode !== groupCode) { lastGroupCode = groupCode; lastGroup = {groupCode: groupCode, avatars: []}; if (lastGroupCode !== '') { avatars.push(lastGroup); } } lastGroup.avatars.push({ code: member.code, name: member.name, avatar: member.photo === null ? "" : member.photo, role: member.type }); } ModelUtil.emitOK(self.eventEmitter, avatars); }); } } module.exports = GroupMessage;