session.repo.js 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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
  23. });
  24. }
  25. /**
  26. * 获取用户全部会话
  27. *
  28. * @param userId
  29. * @param handler
  30. */
  31. static findAll(userId, handler) {
  32. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  33. let sessionSQL = "select id, name, type, create_date, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time from "
  34. + DB_TABLES.Sessions + " s where s.id in(" + sql + ")";
  35. ImDb.execQuery({
  36. "sql": sessionSQL,
  37. "args": [userId],
  38. "handler": handler
  39. });
  40. }
  41. /**
  42. * 获取用户全部会话
  43. *
  44. * @param userId
  45. * @param type
  46. * @param handler
  47. */
  48. static findAllByType(userId, type, handler) {
  49. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? and type=? group by w.session_id";
  50. let sessionSQL = "select id, name, type, create_date, last_sender_id, last_sender_name, last_content_type, last_content, last_message_time from "
  51. + DB_TABLES.Sessions + " s where s.id in(" + sql + ") ";
  52. ImDb.execQuery({
  53. "sql": sessionSQL,
  54. "args": [userId, type],
  55. "handler": handler
  56. });
  57. }
  58. /**
  59. * 按时间跨度查询会话。
  60. *
  61. * @param userId
  62. * @param dateSpan
  63. * @param handler
  64. */
  65. static findAllByTimestampAndType(userId, dateSpan, handler) {
  66. let sql = "SELECT DISTINCT s.id, CASE WHEN TYPE = 2 THEN d.name ELSE s.name END 'name', s.type, s.create_date " +
  67. "FROM sessions s, participants p " +
  68. "LEFT JOIN doctors d ON p.participant_id = d.id " +
  69. "WHERE s.id = p.session_id AND s.last_sender_id <> 'system' " +
  70. "AND UNIX_TIMESTAMP(s.last_message_time) > UNIX_TIMESTAMP(NOW()) - ? " +
  71. "AND p.participant_id <> ? " +
  72. "AND s.id in (select s.id from sessions s, participants p where s.id = p.session_id and p.participant_id = ?) " +
  73. "ORDER BY s.last_message_time DESC";
  74. ImDb.execQuery({
  75. sql: sql,
  76. args: [dateSpan * 3600 * 24, userId, userId],
  77. handler: handler
  78. });
  79. }
  80. /**
  81. * 获取用户置顶会话
  82. *
  83. * @param userId
  84. * @param handler
  85. */
  86. static findStickySessions(userId, handler) {
  87. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  88. 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 + ")";
  89. ImDb.execQuery({
  90. "sql": sessionSQL,
  91. "args": [userId],
  92. "handler": function (err, res) {
  93. if (err) {
  94. log.error("sql:" + sessionSQL + "data:userId:" + userId);
  95. }
  96. handler(err, res);
  97. }
  98. });
  99. }
  100. /**
  101. * 保存session。若会话重复创建,则更新会话名称。
  102. *
  103. * @param sessionId
  104. * @param name
  105. * @param type
  106. * @param createDate
  107. * @param businessType
  108. * @param handler
  109. */
  110. static saveSession(sessionId, name, type, createDate, businessType, handler) {
  111. let sql = "insert into " + DB_TABLES.Sessions + " (id, name, type, create_date,business_type) VALUES (?,?,?,?,?) " +
  112. "ON DUPLICATE KEY UPDATE name = ?";
  113. ImDb.execQuery({
  114. "sql": sql,
  115. "args": [sessionId, name, type, createDate, businessType, name],
  116. "handler": handler
  117. });
  118. }
  119. /**
  120. * 更新会话的最终状态。
  121. *
  122. * @param lastSenderId
  123. * @param lastSenderName
  124. * @param lastMessageTime
  125. * @param lastContent
  126. * @param lastContentType
  127. * @param sessionId
  128. * @param handler
  129. */
  130. static updateSessionLastStatus(lastSenderId, lastSenderName, lastMessageTime, lastContent, lastContentType, sessionId, handler) {
  131. let sql = "update " + DB_TABLES.Sessions + " set last_sender_id=?,last_sender_name=?,last_message_time=?,last_content=?,last_content_type=? where id = ?";
  132. ImDb.execQuery({
  133. "sql": sql,
  134. "args": [lastSenderId, lastSenderName, lastMessageTime, lastContent, lastContentType, sessionId],
  135. "handler": handler || function (err, res) {
  136. log.info("updateSessionLastStatus");
  137. }
  138. });
  139. }
  140. /**
  141. * 保存置顶会话。
  142. *
  143. * @param sessionId
  144. * @param user
  145. * @param score
  146. */
  147. static saveStickySession(sessionId, user, score) {
  148. let sql = "insert into " + DB_TABLES.StickySessions + " (user_id,session_id,score) VALUES (?,?,?) ";
  149. ImDb.execQuery({
  150. "sql": sql,
  151. "args": [user, sessionId, score],
  152. "handler": function (err, res) {
  153. if (err) {
  154. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + user + ",score:" + score);
  155. }
  156. }
  157. });
  158. }
  159. /**
  160. * 取消会话置顶。
  161. *
  162. * @param sessionId
  163. * @param userId
  164. */
  165. static unstickSession(sessionId, userId) {
  166. let sql = "delete from " + DB_TABLES.StickySessions + " where user_id=? and session_id=? ";
  167. ImDb.execQuery({
  168. "sql": sql,
  169. "args": [userId, sessionId],
  170. "handler": function (err, res) {
  171. if (err) {
  172. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + userId);
  173. }
  174. }
  175. });
  176. }
  177. }
  178. module.exports = SessionRepo;