session.repo.js 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  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": function (err, res) {
  23. if (err) {
  24. log.error("sql:" + sessionSQL + "data:sessionId:" + sessionId);
  25. }
  26. handler(err, res);
  27. }
  28. });
  29. }
  30. /**
  31. * 获取用户全部会话
  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 = ? group by w.session_id";
  38. let sessionSQL = "select id,name,type,create_date from " + DB_TABLES.Sessions + " s where s.id in(" + sql + ")";
  39. ImDb.execQuery({
  40. "sql": sessionSQL,
  41. "args": [userId],
  42. "handler": function (err, res) {
  43. if (err) {
  44. log.error("sql:" + sessionSQL + "data:userId:" + userId);
  45. } else {
  46. log.info("getUserSessionsFromMysql success by userId :" + userId);
  47. }
  48. handler(err, res);
  49. }
  50. });
  51. }
  52. /**
  53. * 获取用户置顶会话
  54. *
  55. * @param userId
  56. * @param handler
  57. */
  58. static findStickySessions(userId, handler) {
  59. let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
  60. 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 + ")";
  61. ImDb.execQuery({
  62. "sql": sessionSQL,
  63. "args": [userId],
  64. "handler": function (err, res) {
  65. if (err) {
  66. log.error("sql:" + sessionSQL + "data:userId:" + userId);
  67. }
  68. handler(err, res);
  69. }
  70. });
  71. }
  72. /**
  73. * 保存session。
  74. *
  75. * @param sessionId
  76. * @param name
  77. * @param type
  78. * @param createDate
  79. */
  80. static saveSession(sessionId, name, type, createDate) {
  81. let sql = "insert into " + DB_TABLES.Sessions + " (id,name,type,create_date) VALUES (?,?,?,?) ";
  82. ImDb.execQuery({
  83. "sql": sql,
  84. "args": [sessionId, name, type, createDate],
  85. "handler": function (err, res) {
  86. if (err) {
  87. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",name:" + name + ",type:" + type + ",createDate:" + createDate);
  88. }
  89. }
  90. });
  91. }
  92. /**
  93. * 保存置顶会话。
  94. *
  95. * @param sessionId
  96. * @param user
  97. * @param score
  98. */
  99. static saveStickySession(sessionId, user, score) {
  100. let sql = "insert into " + DB_TABLES.StickySessions + " (user_id,session_id,score) VALUES (?,?,?) ";
  101. ImDb.execQuery({
  102. "sql": sql,
  103. "args": [user, sessionId, score],
  104. "handler": function (err, res) {
  105. if (err) {
  106. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + user + ",score:" + score);
  107. }
  108. }
  109. });
  110. }
  111. /**
  112. * 取消会话置顶。
  113. *
  114. * @param sessionId
  115. * @param userId
  116. */
  117. static unstickSession(sessionId, userId) {
  118. let sql = "delete from " + DB_TABLES.StickySessions + " where user_id=? and session_id=? ";
  119. ImDb.execQuery({
  120. "sql": sql,
  121. "args": [userId, sessionId],
  122. "handler": function (err, res) {
  123. if (err) {
  124. log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + userId);
  125. }
  126. }
  127. });
  128. }
  129. }
  130. module.exports = SessionRepo;