session.repo.js 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  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. class SessionRepo {
  9. constructor() {
  10. }
  11. /**
  12. * 获取单个session对象
  13. *
  14. * @param sessionId
  15. * @param handler
  16. */
  17. static findOne(sessionId, handler) {
  18. let sessionSQL = "select id,name,type,create_date from " + DB_TABLES.Sessions + " s where s.id = ?";
  19. ImDb.execQuery({
  20. "sql": sessionSQL,
  21. "args": [sessionId],
  22. "handler": handler || function (err, res) {
  23. if(err) log.error(err);
  24. }
  25. });
  26. }
  27. /**
  28. * 获取用户全部会话
  29. *
  30. * @param userId
  31. * @param handler
  32. */
  33. static findAll(userId, handler) {
  34. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and participant_role =0 group by w.session_id";
  35. 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";
  36. let sessionSQL = "select id, name, type, create_date, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time,status from "
  37. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.id not in ("+sys_session+")";
  38. ImDb.execQuery({
  39. "sql": sessionSQL,
  40. "args": [userId],
  41. "handler": handler || function (err, res) {
  42. if(err) log.error(err);
  43. }
  44. });
  45. }
  46. /**
  47. * 获取用户全部会话
  48. *
  49. * @param userId
  50. * @param type
  51. * @param handler
  52. */
  53. static findAllByType(userId, type, handler) {
  54. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and type=? group by w.session_id";
  55. let sessionSQL = "select id, name, type, create_date, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time from "
  56. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") ";
  57. ImDb.execQuery({
  58. "sql": sessionSQL,
  59. "args": [userId, type],
  60. "handler": handler || function (err, res) {
  61. if(err) log.error(err);
  62. }
  63. });
  64. }
  65. static findAllByTypeAndStatus(userId, businessType,status,page,pagesize, handler) {
  66. if (page > 0) {
  67. if (page == 1) {
  68. page = 0;
  69. }else{
  70. page = (parseInt(page)-1) * parseInt(pagesize);
  71. }
  72. }
  73. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  74. let sessionSQL = "select * from "
  75. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") and s.business_type = ? and s.status = ? limit "+page+","+pagesize;
  76. ImDb.execQuery({
  77. "sql": sessionSQL,
  78. "args": [userId, businessType,status],
  79. "handler": handler || function (err, res) {
  80. if(err) log.error(err);
  81. }
  82. });
  83. }
  84. /**
  85. * 按时间跨度查询会话。
  86. *
  87. * TODO: 暂时屏蔽与患者相关的会话,包括MUC与患者名医咨询
  88. *
  89. * @param userId
  90. * @param dateSpan
  91. * @param handler
  92. */
  93. static findAllByTimestampAndType(userId, dateSpan, handler) {
  94. let sql = "SELECT DISTINCT s.id, CASE WHEN TYPE = 2 THEN d.name ELSE s.name END 'name', s.type, s.create_date, s.business_type " +
  95. "FROM sessions s, participants p " +
  96. "LEFT JOIN doctors d ON p.participant_id = d.id " +
  97. "WHERE s.id = p.session_id AND s.last_sender_id <> 'system' " +
  98. "AND UNIX_TIMESTAMP(s.last_message_time) > UNIX_TIMESTAMP(NOW()) - ? " +
  99. "AND p.participant_id <> ? AND s.type <> 1 AND s.business_type = 1 " +
  100. "AND s.id in (select s.id from sessions s, participants p where s.id = p.session_id and p.participant_id = ?) " +
  101. "ORDER BY s.last_message_time DESC";
  102. ImDb.execQuery({
  103. sql: sql,
  104. args: [dateSpan * 3600 * 24, userId, userId],
  105. handler: handler || function (err, res) {
  106. if(err) log.error(err);
  107. }
  108. });
  109. }
  110. /**
  111. * 获取用户置顶会话
  112. *
  113. * @param userId
  114. * @param handler
  115. */
  116. static findStickySessions(userId, handler) {
  117. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  118. 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 + ")";
  119. ImDb.execQuery({
  120. "sql": sessionSQL,
  121. "args": [userId],
  122. "handler": handler || function (err, res) {
  123. if(err) log.error(err);
  124. }
  125. });
  126. }
  127. /**
  128. * 保存session。若会话重复创建,则更新会话名称。
  129. *
  130. * @param sessionId
  131. * @param name
  132. * @param type
  133. * @param createDate
  134. * @param businessType
  135. * @param handler
  136. */
  137. static saveSession(sessionId, name, type, createDate, businessType, handler) {
  138. let sql = "insert into " + DB_TABLES.Sessions + " (id, name, type, create_date,business_type) VALUES (?,?,?,?,?) " +
  139. "ON DUPLICATE KEY UPDATE name = ?";
  140. ImDb.execQuery({
  141. "sql": sql,
  142. "args": [sessionId, name, type, createDate, businessType, name],
  143. "handler": handler || function (err, res) {
  144. if(err) log.error(err);
  145. }
  146. });
  147. }
  148. /**
  149. * 更新会话的最终状态。
  150. *
  151. * @param lastSenderId
  152. * @param lastSenderName
  153. * @param lastMessageTime
  154. * @param lastContent
  155. * @param lastContentType
  156. * @param sessionId
  157. * @param handler
  158. */
  159. static updateSessionLastStatus(lastSenderId, lastSenderName, lastMessageTime, lastContent, lastContentType, sessionId, handler) {
  160. let sql = "update " + DB_TABLES.Sessions + " set last_sender_id=?,last_sender_name=?,last_message_time=?,last_content=?,last_content_type=? where id = ?";
  161. ImDb.execQuery({
  162. "sql": sql,
  163. "args": [lastSenderId, lastSenderName, lastMessageTime, lastContent, lastContentType, sessionId],
  164. "handler": handler || function (err, res) {
  165. if(err) log.error(err);
  166. }
  167. });
  168. }
  169. /**
  170. * 保存置顶会话。
  171. *
  172. * @param sessionId
  173. * @param user
  174. * @param score
  175. */
  176. static saveStickySession(sessionId, user, score) {
  177. let sql = "insert into " + DB_TABLES.StickySessions + " (user_id,session_id,score) VALUES (?,?,?) ";
  178. ImDb.execQuery({
  179. "sql": sql,
  180. "args": [user, sessionId, score],
  181. "handler": function (err, res) {
  182. if (err) {
  183. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + user + ",score:" + score);
  184. }
  185. }
  186. });
  187. }
  188. /**
  189. * 取消会话置顶。
  190. *
  191. * @param sessionId
  192. * @param userId
  193. */
  194. static unstickSession(sessionId, userId) {
  195. let sql = "delete from " + DB_TABLES.StickySessions + " where user_id=? and session_id=? ";
  196. ImDb.execQuery({
  197. "sql": sql,
  198. "args": [userId, sessionId],
  199. "handler": function (err, res) {
  200. if (err) {
  201. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + userId);
  202. }
  203. }
  204. });
  205. }
  206. static updateSessionStatus(sessionId,status,handler){
  207. let sql = "update " + DB_TABLES.Sessions + " set status=? where id = ?";
  208. ImDb.execQuery({
  209. "sql": sql,
  210. "args": [status, sessionId],
  211. "handler": handler || function (err, res) {
  212. if(err) log.error(err);
  213. }
  214. });
  215. }
  216. }
  217. module.exports = SessionRepo;