session.repo.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  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 from " + DB_TABLES.Sessions + " s where s.id in(" + sql + ")";
  34. ImDb.execQuery({
  35. "sql": sessionSQL,
  36. "args": [userId],
  37. "handler": handler
  38. });
  39. }
  40. /**
  41. * 获取用户置顶会话
  42. *
  43. * @param userId
  44. * @param handler
  45. */
  46. static findStickySessions(userId, handler) {
  47. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  48. 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 + ")";
  49. ImDb.execQuery({
  50. "sql": sessionSQL,
  51. "args": [userId],
  52. "handler": function (err, res) {
  53. if (err) {
  54. log.error("sql:" + sessionSQL + "data:userId:" + userId);
  55. }
  56. handler(err, res);
  57. }
  58. });
  59. }
  60. /**
  61. * 保存session。若会话重复创建,则更新会话名称。
  62. *
  63. * @param sessionId
  64. * @param name
  65. * @param type
  66. * @param createDate
  67. * @param handler
  68. */
  69. static saveSession(sessionId, name, type, createDate, handler) {
  70. let sql = "insert into " + DB_TABLES.Sessions + " (id, name, type, create_date) VALUES (?,?,?,?) " +
  71. "ON DUPLICATE KEY UPDATE name = ?";
  72. ImDb.execQuery({
  73. "sql": sql,
  74. "args": [sessionId, name, type, createDate, name],
  75. "handler": handler
  76. });
  77. }
  78. /**
  79. * 保存置顶会话。
  80. *
  81. * @param sessionId
  82. * @param user
  83. * @param score
  84. */
  85. static
  86. saveStickySession(sessionId, user, score) {
  87. let sql = "insert into " + DB_TABLES.StickySessions + " (user_id,session_id,score) VALUES (?,?,?) ";
  88. ImDb.execQuery({
  89. "sql": sql,
  90. "args": [user, sessionId, score],
  91. "handler": function (err, res) {
  92. if (err) {
  93. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + user + ",score:" + score);
  94. }
  95. }
  96. });
  97. }
  98. /**
  99. * 取消会话置顶。
  100. *
  101. * @param sessionId
  102. * @param userId
  103. */
  104. static
  105. unstickSession(sessionId, userId) {
  106. let sql = "delete from " + DB_TABLES.StickySessions + " where user_id=? and session_id=? ";
  107. ImDb.execQuery({
  108. "sql": sql,
  109. "args": [userId, sessionId],
  110. "handler": function (err, res) {
  111. if (err) {
  112. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + userId);
  113. }
  114. }
  115. });
  116. }
  117. }
  118. module.exports = SessionRepo;