topics.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. /**
  2. * 议题模型。
  3. */
  4. "use strict";
  5. let RedisClient = require('../../repository/redis/redis.client.js');
  6. let TopicsRepo = require('../../repository/mysql/topics.repo');
  7. let SessionRepo = require('../../repository/mysql/session.repo');
  8. let ParticipantRepo = require('../../repository/mysql/participant.repo');
  9. let RedisModel = require('./../redis.model.js');
  10. let ModelUtil = require('../../util/model.util');
  11. let Sessions = require("./sessions");
  12. let log = require('../../util/log.js');
  13. let redis = RedisClient.redisClient().connection;
  14. let configFile = require('../../include/commons').CONFIG_FILE;
  15. let config = require('../../resources/config/' + configFile);
  16. const REDIS_KEYS = require('../../include/commons').REDIS_KEYS;
  17. const TOPIC_STATUS = require('../../include/commons').TOPIC_STATUS;
  18. const SESSION_STATUS = require('../../include/commons').SESSION_STATUS;
  19. const SESSION_TYPES = require('../../include/commons').SESSION_TYPES;
  20. class Topics extends RedisModel {
  21. constructor() {
  22. super();
  23. }
  24. getTopics(user, status, page, pagesize, sessionType) {
  25. let self = this;
  26. let session = new Sessions();
  27. page = (page - 1 < 0 ? 0 : page - 1) * pagesize;
  28. if (!pagesize) pagesize = 10;
  29. pagesize = parseInt(pagesize);
  30. if (!sessionType) sessionType = SESSION_TYPES.MUC;
  31. SessionRepo.findAllByType(user, sessionType, function (err, res) {
  32. if (err) {
  33. ModelUtil.emitError(self.eventEmitter, "获取列表失败" + err);
  34. } else if (res && res.length == 0) {
  35. ModelUtil.emitOK(self.eventEmitter, []);
  36. }
  37. var sessionIds = [];
  38. for (var j in res) {
  39. sessionIds.push(res[j].id);
  40. }
  41. TopicsRepo.findAllBySessionIdsAndStatus(sessionIds, status, page, pagesize, function (err, res) {
  42. if (err) {
  43. ModelUtil.emitError(self.eventEmitter, "获取列表失败" + err);
  44. }
  45. else if (res && res.length == 0) {
  46. ModelUtil.emitOK(self.eventEmitter, []);
  47. } else {
  48. for (var j = 0; j < res.length; j++) {
  49. callAmount(j, res, res[j]);
  50. }
  51. }
  52. function callAmount(i, res, r) {
  53. session.getSessionUnreadMessageCount(res[i].session_id, user, function (err, msgcount) {
  54. if (err) {
  55. log.error("getSessionUnreadMessageCount is error:" + err);
  56. ModelUtil.emitError(self.eventEmitter, "获取未读消息失败!" + err);
  57. } else {
  58. callGetImg(i, res, r, msgcount);
  59. }
  60. })
  61. }
  62. var result = [];
  63. function callGetImg(i, res, r, msgcount) {
  64. ParticipantRepo.findAll(res[i].session_id, function (err, p) {
  65. if (err) {
  66. log.error("获取头像失败:" + err);
  67. } else {
  68. r.create_time = r.create_time.getTime();
  69. for (var j in p) {
  70. if (p[j].is_patient) {
  71. r.avatar = p[j].avatar;
  72. r.patient = p[j].id;
  73. r.patient_name = p[j].name;
  74. r.sex = p[j].sex;
  75. r.birthdate = p[j].birthdate.getTime();
  76. if (r.status != TOPIC_STATUS.ENDED) {
  77. r.msg_count = msgcount;
  78. }
  79. }
  80. }
  81. result.push(r);
  82. if (result.length == res.length) {
  83. ModelUtil.emitOK(self.eventEmitter, res);
  84. }
  85. }
  86. })
  87. }
  88. })
  89. })
  90. }
  91. /**
  92. * 根据topicId获取对应的消息
  93. * @param topicId
  94. * @param user
  95. * @param startMsgId
  96. * @param endMsgId
  97. * @param page
  98. * @param pagesize
  99. */
  100. getTopicMessages(topicId, user, startMsgId, endMsgId, page, pagesize) {
  101. let self = this;
  102. TopicsRepo.findAllByTopicId(topicId, function (err, res) {
  103. if (err || res.length == 0) {
  104. ModelUtil.emitOK(self.eventEmitter, {status: -1, message: "找不到对应的会话记录!"});
  105. }
  106. if(!res[0]||!res[0].session_id){
  107. ModelUtil.emitOK(self.eventEmitter, {status: -1, message: err});
  108. }
  109. let sessions = new Sessions();
  110. sessions.getMessages(res[0].session_id, user, startMsgId, endMsgId, page, pagesize, 0, function (err, messages) {
  111. if (err) {
  112. ModelUtil.emitOK(self.eventEmitter, {status: 200, data: {"list":[],"users":[]}});
  113. } else {
  114. if (messages && messages.length > 0) {
  115. ParticipantRepo.findAll(res[0].session_id, function (err, users) {
  116. if (err) {
  117. ModelUtil.emitOK(self.eventEmitter, {status: -1, message: err});
  118. } else {
  119. ModelUtil.emitOK(self.eventEmitter, {status: 200, data: {"list": messages, "users": users}});
  120. }
  121. })
  122. } else {
  123. ModelUtil.emitOK(self.eventEmitter, {status: 200, data: []});
  124. }
  125. }
  126. });
  127. })
  128. }
  129. /**
  130. * 创建议题。
  131. *
  132. * @param topicName 发起议题的名称
  133. * @param topicId
  134. * @param sessionId
  135. * @param users 发起议题的患者,格式:{"userId1:role", "userId2:role"}
  136. * @param messages 发送的消息对象,格式:{description:"",title:"",img:"image1,image2",sender_id:"",sender_name:""},多个图片用逗号隔开
  137. */
  138. createTopic(topicName, topicId, sessionId, users, messages, sessionType) {
  139. let self = this;
  140. if (!sessionId && sessionType == SESSION_TYPES.MUC) {
  141. ModelUtil.emitOK(self.eventEmitter, {status: -1, message: "会话ID为空,请先生成会话ID"});
  142. return;
  143. }
  144. if (!topicId) {
  145. ModelUtil.emitOK(self.eventEmitter, {status: -1, message: "议题ID为空,请先生成议题ID"});
  146. return;
  147. }
  148. var pars = [];
  149. for (var j in users) {
  150. pars.push(j + ":" + users[j]);
  151. }
  152. let sessions = new Sessions();
  153. let date = new Date();
  154. sessions.createSession(sessionId, messages.sender_name, sessionType, pars, function (err, res) {
  155. sessionId = res.id;
  156. self.saveTopicToRedis(topicName, topicId, sessionId, messages, date, function (err, res) {
  157. if (err) {
  158. ModelUtil.emitOK(self.eventEmitter, {status: -1, message: "议题创建失败!"});
  159. return;
  160. }
  161. //返回给前端
  162. ModelUtil.emitOK(self.eventEmitter, {status: 200, message: "议题创建成功!", start_msg_id: res});
  163. sessions.updateSessionStatus(sessionId,0);
  164. //执行数据库操作
  165. self.saveTopicToMySQL(topicName, topicId, sessionId, res, date, messages.description, TOPIC_STATUS.NEW, function (err, res) {
  166. if (err) {
  167. ModelUtil.logError("Save topic to mysql failed", err);
  168. }
  169. })
  170. })
  171. });
  172. }
  173. saveTopicToRedis(topicName, topicId, sessionId, messages, date, handler) {
  174. let topics_key = RedisModel.makeRedisKey(REDIS_KEYS.Topics, sessionId);
  175. let topic_key = RedisModel.makeRedisKey(REDIS_KEYS.Topic, topicId);
  176. let sessions = new Sessions();
  177. //step1:创建topic到redis
  178. redis.zaddAsync(topics_key, date.getTime(), topicId).then(function (res) {
  179. redis.hmsetAsync(topic_key, "name", topicName,
  180. "session_id", sessionId, "create_time", date.getTime(),
  181. "description", messages.description, "status", TOPIC_STATUS.NEW,
  182. "end_time", "", "end_by", ""
  183. ).then(function (res) {
  184. sendBeginMsg();
  185. }).catch(function (err) {
  186. handler(err, null);
  187. return;
  188. });
  189. }).catch(function (err) {
  190. handler(err, null);
  191. return;
  192. });
  193. //step2:发送开始会话
  194. function sendBeginMsg() {
  195. let msg = {};
  196. msg.sender_id = messages.sender_id;
  197. msg.sender_name = "系统";//messages.sender_name;发起和结束咨询的消息由系统发出,发送者ID记录操作人!
  198. msg.content_type = 10;
  199. msg.content = messages.sender_name + "发起了咨询";
  200. msg.timestamp = date;
  201. sessions.saveMessageByTopic(msg, sessionId, function (err, msgId) {
  202. if (err) {
  203. handler(err, null);
  204. } else {
  205. sendQuesionMsg(msgId);
  206. handler(null, msgId);
  207. }
  208. })
  209. }
  210. //step3:发送求助内容的文本
  211. function sendQuesionMsg(startMsgId) {
  212. let msg = {};
  213. msg.sender_id = messages.sender_id;
  214. msg.sender_name = messages.sender_name;
  215. msg.content_type = 6;
  216. msg.content = messages.description;
  217. msg.timestamp = new Date(new Date().getTime());
  218. sessions.saveMessageByTopic(msg, sessionId, function (err, msgId) {
  219. if (messages.img) {
  220. setTimeout(function(){
  221. sendQuesionImg(startMsgId);
  222. },100);
  223. }
  224. if (err) {
  225. log.info("send create message error " + msg);
  226. }
  227. });
  228. }
  229. //step4:发送求助内容的图片
  230. function sendQuesionImg(startMsgId) {
  231. let imgs = messages.img.split(",");
  232. for (var j in imgs) {
  233. let msgimg = {};
  234. msgimg.sender_id = messages.sender_id;
  235. msgimg.sender_name = messages.sender_name;
  236. msgimg.content_type = 2;
  237. msgimg.content = imgs[j];
  238. msgimg.timestamp = new Date(new Date().getTime());
  239. sessions.saveMessageByTopic(msgimg, sessionId, function (err, msgId) {
  240. if (err) {
  241. log.info("send create img error " + imgs[j]);
  242. }
  243. })
  244. }
  245. }
  246. }
  247. saveTopicToMySQL(topicName, topicId, sessionId, messageId, date, description, status, handler) {
  248. TopicsRepo.saveTopic(topicName, topicId, sessionId, messageId, date, description, status, handler);
  249. }
  250. /**
  251. * 议题是否已结束。
  252. *
  253. * @param sessionId
  254. * @param topicId
  255. * @param handler
  256. */
  257. isTopicEnded(sessionId, topicId, handler) {
  258. let self = this;
  259. if (topicId == "current") {
  260. TopicsRepo.findLastTopicStatus(sessionId, callback);
  261. } else {
  262. TopicsRepo.findTopicStatus(topicId, callback);
  263. }
  264. function callback(err, res) {
  265. if (err) {
  266. handler != null ? handler(err, res) : ModelUtil.emitError(self.eventEmitter, err);
  267. } else {
  268. if (null == res) {
  269. handler != null ? handler(err, res) : ModelUtil.emitOK(self.eventEmitter, {});
  270. } else {
  271. let ended = res[0].status == TOPIC_STATUS.ENDED;
  272. handler != null ? handler(err, res) : ModelUtil.emitOK(self.eventEmitter, res[0]);
  273. }
  274. }
  275. }
  276. }
  277. /**
  278. * 结束议题
  279. * @param topicId
  280. * @param endUser
  281. * @param endUserName
  282. */
  283. endTopic(topicId, endUser, endUserName) {
  284. let endDate = new Date();
  285. let self = this;
  286. let topic_key = RedisModel.makeRedisKey(REDIS_KEYS.Topic, topicId);
  287. redis.hmsetAsync(topic_key, "end_time", endDate.getTime(), "end_by", endUser, "status", TOPIC_STATUS.ENDED).then(function (res) {
  288. redis.hgetallAsync(topic_key).then(function (topic) {
  289. callEnd(topic.session_id);
  290. })
  291. });
  292. /**
  293. * 结束消息发送
  294. */
  295. function callEnd(sessionId) {
  296. let msg = {
  297. sender_id: endUser,
  298. sender_name: "系统",//endUserName,发起和结束咨询的消息由系统发出,发送者ID记录操作人!
  299. content_type: 7,
  300. content: endUserName + "结束了咨询",
  301. timestamp: new Date()
  302. };
  303. let sessions = new Sessions();
  304. sessions.saveMessageByTopic(msg, sessionId, function (err, msgId) {
  305. if (err) {
  306. ModelUtil.emitOK(self.eventEmitter, {status: -1, "message": err});
  307. } else {
  308. ModelUtil.emitOK(self.eventEmitter, {status: 200, "id": msgId, "message": "结束成功!"});
  309. TopicsRepo.endTopic(topicId, endUser, msg.timestamp, msgId, TOPIC_STATUS.ENDED);
  310. sessions.updateSessionStatus(sessionId,SESSION_STATUS.ENDED);
  311. }
  312. })
  313. }
  314. }
  315. updateTopic(topicId, valueJson) {
  316. let self = this;
  317. let topickey = RedisModel.makeRedisKey(REDIS_KEYS.Topic, topicId);
  318. var dataArray = [];
  319. for (var j in valueJson) {
  320. dataArray.push(j);
  321. dataArray.push(valueJson[j]);
  322. }
  323. redis.hmsetAsync(topickey, dataArray).then(function (res) {
  324. TopicsRepo.updateTopics(topicId, valueJson, function (err, res) {
  325. if (!err) {
  326. ModelUtil.emitOK(self.eventEmitter, {"status": 200});
  327. } else {
  328. ModelUtil.emitOK(self.eventEmitter, {"status": -1});
  329. }
  330. });
  331. });
  332. }
  333. getTopicByTopicId(topicId){
  334. let self = this;
  335. TopicsRepo.findAllByTopicId(topicId,function (err,res) {
  336. if (!err) {
  337. ModelUtil.emitOK(self.eventEmitter, {"status": 200,"data":res});
  338. } else {
  339. ModelUtil.emitOK(self.eventEmitter, {"status": -1});
  340. }
  341. })
  342. }
  343. }
  344. // Expose class
  345. module.exports = Topics;