|
@ -356,6 +356,58 @@ class WechatClient extends RedisModel {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 推送MDT,医生外层新消息
|
|
|
* @param doctorId
|
|
|
* @param message
|
|
|
*/
|
|
|
static sendMDTSocketMessageToDoctor(doctorId, message) {
|
|
|
// let doctorMDTClient = clientCache.findByIdAndType("pcim_"+doctorId,SOCKET_TYPES.PCIM_DOCTOR);
|
|
|
let doctorSYSTEMClient = clientCache.findByIdAndType("pc_system_"+doctorId,SOCKET_TYPES.PC_DOCTOR_SYSTEM);
|
|
|
let doctorAPPSYSTEMClient = clientCache.findByIdAndType("doctor_system_"+doctorId,SOCKET_TYPES.DOCTOR_SYSTEM);
|
|
|
|
|
|
//外层
|
|
|
if(!doctorSYSTEMClient){
|
|
|
log.warn("target system doctor is not online!");
|
|
|
}else{
|
|
|
doctorSYSTEMClient.socket.emit('message', {
|
|
|
id: message.id,
|
|
|
session_id: message.session_id,
|
|
|
sender_id: message.sender_id,
|
|
|
sender_name: message.sender_name,
|
|
|
content_type: 1,
|
|
|
content: {"socket_sms_type":4},
|
|
|
timestamp: ObjectUtil.timestampToLong(message.timestamp),
|
|
|
type: message.content_type, // legacy support
|
|
|
name: message.sender_name,
|
|
|
patient_name:message.patient_name,
|
|
|
patient_age:message.patient_age,
|
|
|
patient_sex:message.patient_sex
|
|
|
});
|
|
|
}
|
|
|
|
|
|
if(!doctorAPPSYSTEMClient){
|
|
|
log.warn("target system app doctor is not online!");
|
|
|
}else{
|
|
|
doctorAPPSYSTEMClient.socket.emit('message', {
|
|
|
id: message.id,
|
|
|
session_id: message.session_id,
|
|
|
sender_id: message.sender_id,
|
|
|
sender_name: message.sender_name,
|
|
|
content_type: 1,
|
|
|
content: {"socket_sms_type":4},
|
|
|
timestamp: ObjectUtil.timestampToLong(message.timestamp),
|
|
|
type: message.content_type, // legacy support
|
|
|
name: message.sender_name,
|
|
|
patient_name:message.patient_name,
|
|
|
patient_age:message.patient_age,
|
|
|
patient_sex:message.patient_sex
|
|
|
});
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
static sendPcImSocket(targetId, message, sessionType) {
|
|
|
if (message.content_type == CONTENT_TYPES.PlainText ||
|
|
|
message.content_type == CONTENT_TYPES.Image ||
|
|
@ -378,9 +430,19 @@ class WechatClient extends RedisModel {
|
|
|
session_type: sessionType,
|
|
|
from: message.sender_id|| '',
|
|
|
data: message.content,
|
|
|
business_type: message.business_type || 1
|
|
|
business_type: message.business_type || 1,
|
|
|
sender_name: message.sender_name,
|
|
|
content_type: message.content_type,
|
|
|
content: message.content,
|
|
|
timestamp: ObjectUtil.timestampToLong(message.timestamp),
|
|
|
type: message.content_type, // legacy support
|
|
|
name: message.sender_name,
|
|
|
patient_name:message.patient_name,
|
|
|
patient_age:message.patient_age,
|
|
|
patient_sex:message.patient_sex
|
|
|
});
|
|
|
|
|
|
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@ -548,6 +610,41 @@ class WechatClient extends RedisModel {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
//推送托盘消息
|
|
|
static sendMDTSystemSocketMessage(targetUserId, message) {
|
|
|
|
|
|
//居民外层消息推送
|
|
|
|
|
|
let mdtDcotorClient = clientCache.findByIdAndType("pcim_"+targetUserId,SOCKET_TYPES.PCIM_DOCTOR);
|
|
|
if(!mdtDcotorClient){
|
|
|
log.warn("target mdt doctor is not online!");
|
|
|
}
|
|
|
|
|
|
var mdtDoctorCount = 0;
|
|
|
|
|
|
|
|
|
if(mdtDcotorClient&&message.session_id==mdtDcotorClient.sessionId){
|
|
|
WechatClient.updateParticipantLastFetchTime(mdtDcotorClient.sessionId, targetUserId, ObjectUtil.timestampToLong(message.timestamp));
|
|
|
mdtDcotorClient.socket.emit('message', {
|
|
|
id: message.id,
|
|
|
session_id: message.session_id,
|
|
|
sender_id: message.sender_id,
|
|
|
sender_name: message.sender_name,
|
|
|
content_type: message.content_type,
|
|
|
content: message.content,
|
|
|
timestamp: ObjectUtil.timestampToLong(message.timestamp),
|
|
|
type: message.content_type, // legacy support
|
|
|
name: message.sender_name,
|
|
|
});
|
|
|
}else{
|
|
|
mdtDoctorCount++;
|
|
|
}
|
|
|
|
|
|
if(mdtDoctorCount==2){
|
|
|
log.warn("doctor system is not in the same session or is not online");
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
*
|
|
|
* 发送微信模板消息给居民
|