session.repo.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. /**
  2. * 会话库。
  3. */
  4. "use strict";
  5. let ImDb = require('../mysql/db/im.db');
  6. let log = require('../../util/log.js');
  7. const DB_TABLES = require('../../include/commons').DB_TABLES;
  8. const PARTICIPANT_ROLES = require('../../include/commons').PARTICIPANT_ROLES;
  9. const SESSION_STATUS = require('../../include/commons').SESSION_STATUS;
  10. const SESSION_BUSINESS_TYPE = require('../../include/commons').SESSION_BUSINESS_TYPE;
  11. class SessionRepo {
  12. constructor() {
  13. }
  14. /**
  15. * 获取单个session对象
  16. *
  17. * @param sessionId
  18. * @param handler
  19. */
  20. static findOne(sessionId, handler) {
  21. let sessionSQL = "select id,name,type,create_date,business_type from " + DB_TABLES.Sessions + " s where s.id = ?";
  22. ImDb.execQuery({
  23. "sql": sessionSQL,
  24. "args": [sessionId],
  25. "handler": handler || function (err, res) {
  26. if(err) log.error(err);
  27. }
  28. });
  29. }
  30. /**
  31. * 获取用户全部会话不包含角色未1的会话
  32. *
  33. * @param userId
  34. * @param handler
  35. */
  36. static findAll(userId, handler) {
  37. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and participant_role =0 group by w.session_id";
  38. let sys_session = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = 'system' and participant_role =0 group by w.session_id";
  39. let sessionSQL = "select id, name, type, create_date,business_type, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time,status from "
  40. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.id not in ("+sys_session+")";
  41. ImDb.execQuery({
  42. "sql": sessionSQL,
  43. "args": [userId],
  44. "handler": handler || function (err, res) {
  45. if(err) log.error(err);
  46. }
  47. });
  48. }
  49. /**
  50. * 获取用户全部(未结束的)会话不包含角色未1的会话
  51. * @param userId
  52. * @param handler
  53. */
  54. static findUnEndAll(userId, handler) {
  55. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and participant_role =0 group by w.session_id";
  56. let sys_session = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = 'system' and participant_role =0 group by w.session_id";
  57. let sessionSQL = "select id, name, type, create_date,business_type, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time,status from "
  58. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.id not in ("+sys_session+") and s.`status` = 0";
  59. ImDb.execQuery({
  60. "sql": sessionSQL,
  61. "args": [userId],
  62. "handler": handler || function (err, res) {
  63. if(err) log.error(err);
  64. }
  65. });
  66. }
  67. /**
  68. * 获取用户全部会话忽略角色
  69. *
  70. * @param userId
  71. * @param handler
  72. */
  73. static findAllIgnoreRole(userId, handler) {
  74. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  75. let sys_session = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = 'system' and participant_role =0 group by w.session_id";
  76. let sessionSQL = "select id, name, type, create_date,business_type, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time,status from "
  77. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.id not in ("+sys_session+")";
  78. ImDb.execQuery({
  79. "sql": sessionSQL,
  80. "args": [userId],
  81. "handler": handler || function (err, res) {
  82. if(err) log.error(err);
  83. }
  84. });
  85. }
  86. /**
  87. * 获取用户全部会话
  88. *
  89. * @param userId
  90. * @param type
  91. * @param handler
  92. */
  93. static findAllByType(userId, type, handler) {
  94. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and type=? group by w.session_id";
  95. let sessionSQL = "select id, name, type, create_date, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time from "
  96. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") ";
  97. log.info("获取用户全部会话: sql :" + sql);
  98. log.info("获取用户全部会话: args :" + args);
  99. ImDb.execQuery({
  100. "sql": sessionSQL,
  101. "args": [userId, type],
  102. "handler": handler || function (err, res) {
  103. if(err) log.error(err);
  104. }
  105. });
  106. }
  107. /**
  108. * 查找某类型的用户的会话数量
  109. * @param userId
  110. * @param type
  111. * @param handler
  112. */
  113. static findSessionCountByType(userId,type,status,handler){
  114. let sql = "select session_id count from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  115. let sessionSQL = "select count(id) count from " + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.type=?";
  116. if(status != null){
  117. sessionSQL = sessionSQL + " and s.status="+status;
  118. }
  119. ImDb.execQuery({
  120. "sql": sessionSQL,
  121. "args": [userId, type],
  122. "handler": handler || function (err, res) {
  123. if(err) log.error(err);
  124. }
  125. });
  126. }
  127. /**
  128. * 分页获取用户会话列表
  129. * @param userId
  130. * @param type
  131. * @param handler
  132. */
  133. static findListByType(userId, type,page,pagesize, status,handler) {
  134. log.info("type="+type);
  135. if (page > 0) {
  136. if (page == 1) {
  137. page = 0;
  138. }else{
  139. page = (parseInt(page)-1) * parseInt(pagesize);
  140. }
  141. }
  142. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id in(?) group by w.session_id";
  143. let sessionSQL = "select id, name, type, create_date, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time from "
  144. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.type in("+type+") ";
  145. if(status != null && status != ""){
  146. sessionSQL += " and s.status="+status
  147. }
  148. sessionSQL += " order by s.last_message_time desc limit "+page+","+pagesize;
  149. log.info(sessionSQL)
  150. ImDb.execQuery({
  151. "sql": sessionSQL,
  152. "args": [userId],
  153. "handler": handler || function (err, res) {
  154. if(err) log.error(err);
  155. }
  156. });
  157. }
  158. static findAllByTypeAndStatus(userId, businessType,status,page,pagesize, handler) {
  159. if (page > 0) {
  160. if (page == 1) {
  161. page = 0;
  162. }else{
  163. page = (parseInt(page)-1) * parseInt(pagesize);
  164. }
  165. }
  166. let sessionSQL ="";
  167. let sql ="";
  168. if(status == SESSION_STATUS.ENDED){
  169. if(businessType == SESSION_BUSINESS_TYPE.PATIENT){//区分居民,有未读消息的置顶排列
  170. //找出已经结束的咨询
  171. sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  172. //找出角色讨论组中为旁听且未结束的咨询
  173. let sql1 = ("select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and participant_role ="+PARTICIPANT_ROLES.REGULAR+" group by w.session_id")
  174. sessionSQL = "select s.* from " + DB_TABLES.Sessions + " s, " + DB_TABLES.Participants + " p " +
  175. " where ((s.id in(" + sql + ") and s.business_type = ? and s.status = 1) or (s.id in(" + sql1 + ") and s.business_type = ? and s.status = 0)) " +
  176. // " and s.id = p.session_id and p.participant_id = ? ORDER BY (p.last_fetch_time - s.last_message_time+1)>0,s.create_date desc limit "+page+","+pagesize;
  177. " and s.id = p.session_id and p.participant_id = ? ORDER BY s.last_message_time desc limit "+page+","+pagesize;
  178. ImDb.execQuery({
  179. "sql": sessionSQL,
  180. "args": [userId, businessType,userId,businessType,userId],
  181. "handler": handler || function (err, res) {
  182. if(err) log.error(err);
  183. }
  184. });
  185. }else{
  186. //找出已经结束的咨询
  187. sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  188. //找出角色讨论组中为旁听且未结束的咨询
  189. let sql1 = ("select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and participant_role ="+PARTICIPANT_ROLES.REGULAR+" group by w.session_id")
  190. sessionSQL = "select * from "
  191. + DB_TABLES.Sessions + " s where (s.id in(" + sql + ") and s.business_type = ? and s.status = 1) or (s.id in(" + sql1 + ") and s.business_type = ? and s.status = 0) limit "+page+","+pagesize;
  192. log.info("findAllByTypeAndStatus: sql " + sessionSQL);
  193. log.info("findAllByTypeAndStatus: args " + [userId, businessType,userId,businessType]);
  194. ImDb.execQuery({
  195. "sql": sessionSQL,
  196. "args": [userId, businessType,userId,businessType],
  197. "handler": handler || function (err, res) {
  198. if(err) log.error(err);
  199. }
  200. });
  201. }
  202. }else{
  203. sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and participant_role ="+PARTICIPANT_ROLES.HOST+" group by w.session_id";
  204. sessionSQL = "select * from "
  205. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.business_type = ? and s.status = ? limit "+page+","+pagesize;
  206. log.info("findAllByTypeAndStatus: sql : "+sessionSQL);
  207. log.info("findAllByTypeAndStatus: args : "+[userId, businessType,status]);
  208. ImDb.execQuery({
  209. "sql": sessionSQL,
  210. "args": [userId, businessType,status],
  211. "handler": handler || function (err, res) {
  212. if(err) log.error(err);
  213. }
  214. });
  215. }
  216. }
  217. static findAllByType(userId, businessType,page,pagesize, handler) {
  218. if (page > 0) {
  219. if (page == 1) {
  220. page = 0;
  221. }else{
  222. page = (parseInt(page)-1) * parseInt(pagesize);
  223. }
  224. }
  225. // MDT 不执行 businessType 的过滤查询 20191028
  226. if(businessType){
  227. let sessionSQL ="";
  228. let sql ="";
  229. //sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and participant_role ="+PARTICIPANT_ROLES.HOST+" group by w.session_id";
  230. //中山医院无法查询到所有会话记录,暂时取消participant_role的判断条件 20190619
  231. sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  232. sessionSQL = "select * from "
  233. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.business_type = ? and s.type!=0 limit "+page+","+pagesize;
  234. ImDb.execQuery({
  235. "sql": sessionSQL,
  236. "args": [userId, businessType],
  237. "handler": handler || function (err, res) {
  238. if(err) log.error(err);
  239. }
  240. });
  241. }else{
  242. let sessionSQL ="";
  243. let sql ="";
  244. //sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and participant_role ="+PARTICIPANT_ROLES.HOST+" group by w.session_id";
  245. //中山医院无法查询到所有会话记录,暂时取消participant_role的判断条件 20190619
  246. sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  247. sessionSQL = "select * from "
  248. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.type!=0 limit "+page+","+pagesize;
  249. ImDb.execQuery({
  250. "sql": sessionSQL,
  251. "args": [userId],
  252. "handler": handler || function (err, res) {
  253. if(err) log.error(err);
  254. }
  255. });
  256. }
  257. }
  258. /**
  259. * 按时间跨度查询会话。
  260. *
  261. * TODO: 暂时屏蔽与患者相关的会话,包括MUC与患者名医咨询
  262. *
  263. * @param userId
  264. * @param dateSpan
  265. * @param handler
  266. */
  267. static findAllByTimestampAndType(userId, dateSpan, handler) {
  268. let sql = "SELECT DISTINCT s.id, CASE WHEN TYPE = 2 THEN d.name ELSE s.name END 'name',s.last_content_type, s.type, s.create_date, s.business_type " +
  269. "FROM sessions s, participants p " +
  270. "LEFT JOIN doctors d ON p.participant_id = d.id " +
  271. "WHERE s.id = p.session_id AND s.last_sender_id <> 'system' " +
  272. "AND UNIX_TIMESTAMP(s.last_message_time) > UNIX_TIMESTAMP(NOW()) - ? " +
  273. "AND p.participant_id <> ? AND s.type <> 1 AND s.business_type = 1 " +
  274. "AND s.id in (select s.id from sessions s, participants p where s.id = p.session_id and p.participant_id = ?) " +
  275. "ORDER BY s.last_message_time DESC";
  276. ImDb.execQuery({
  277. sql: sql,
  278. args: [dateSpan * 3600 * 24, userId, userId],
  279. handler: handler || function (err, res) {
  280. if(err) log.error(err);
  281. }
  282. });
  283. }
  284. /**
  285. * 获取用户置顶会话
  286. *
  287. * @param userId
  288. * @param handler
  289. */
  290. static findStickySessions(userId, handler) {
  291. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  292. let sessionSQL = "select s.id,s.name,s.type,s.create_date from " + DB_TABLES.Sessions + " s," + DB_TABLES.StickySessions + " ss where s.id = ss.session_id s.id in(" + sql + ")";
  293. ImDb.execQuery({
  294. "sql": sessionSQL,
  295. "args": [userId],
  296. "handler": handler || function (err, res) {
  297. if(err) log.error(err);
  298. }
  299. });
  300. }
  301. /**
  302. * 保存session。若会话重复创建,则更新会话名称。
  303. *
  304. * @param sessionId
  305. * @param name
  306. * @param type
  307. * @param createDate
  308. * @param businessType
  309. * @param handler
  310. */
  311. static saveSession(sessionId, name, type, createDate, businessType, handler) {
  312. let sql = "insert into " + DB_TABLES.Sessions + " (id, name, type, create_date,business_type) VALUES (?,?,?,?,?) " +
  313. "ON DUPLICATE KEY UPDATE name = ?,type = ?";
  314. ImDb.execQuery({
  315. "sql": sql,
  316. "args": [sessionId, name, type, createDate, businessType, name,type],
  317. "handler": handler || function (err, res) {
  318. if(err) log.error(err);
  319. }
  320. });
  321. }
  322. /**
  323. * 更新会话的最终状态。
  324. *
  325. * @param lastSenderId
  326. * @param lastSenderName
  327. * @param lastMessageTime
  328. * @param lastContent
  329. * @param lastContentType
  330. * @param sessionId
  331. * @param handler
  332. */
  333. static updateSessionLastStatus(lastSenderId, lastSenderName, lastMessageTime, lastContent, lastContentType, sessionId, handler) {
  334. let sql = "update " + DB_TABLES.Sessions + " set last_sender_id=?,last_sender_name=?,last_message_time=?,last_content=?,last_content_type=? where id = ?";
  335. ImDb.execQuery({
  336. "sql": sql,
  337. "args": [lastSenderId, lastSenderName, lastMessageTime, lastContent, lastContentType, sessionId],
  338. "handler": handler || function (err, res) {
  339. if(err) log.error(err);
  340. }
  341. });
  342. }
  343. /**
  344. * 保存置顶会话。
  345. *
  346. * @param sessionId
  347. * @param user
  348. * @param score
  349. */
  350. static saveStickySession(sessionId, user, score) {
  351. let sql = "insert into " + DB_TABLES.StickySessions + " (user_id,session_id,score) VALUES (?,?,?) ";
  352. ImDb.execQuery({
  353. "sql": sql,
  354. "args": [user, sessionId, score],
  355. "handler": function (err, res) {
  356. if (err) {
  357. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + user + ",score:" + score);
  358. }
  359. }
  360. });
  361. }
  362. /**
  363. * 取消会话置顶。
  364. *
  365. * @param sessionId
  366. * @param userId
  367. */
  368. static unStickySession(sessionId, userId) {
  369. let sql = "delete from " + DB_TABLES.StickySessions + " where user_id=? and session_id=? ";
  370. ImDb.execQuery({
  371. "sql": sql,
  372. "args": [userId, sessionId],
  373. "handler": function (err, res) {
  374. if (err) {
  375. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + userId);
  376. }
  377. }
  378. });
  379. }
  380. static updateSessionStatus(sessionId,status,handler){
  381. let sql = "update " + DB_TABLES.Sessions + " set status=? where id = ?";
  382. ImDb.execQuery({
  383. "sql": sql,
  384. "args": [status, sessionId],
  385. "handler": handler || function (err, res) {
  386. if(err) log.error(err);
  387. }
  388. });
  389. }
  390. static updateSessionName(sessionId,name,handler){
  391. let sql = "update " + DB_TABLES.Sessions + " set name=? where id = ?";
  392. ImDb.execQuery({
  393. "sql": sql,
  394. "args": [name, sessionId],
  395. "handler": handler || function (err, res) {
  396. if(err) log.error(err);
  397. }
  398. });
  399. }
  400. }
  401. module.exports = SessionRepo;