message.repo.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /**
  2. * 消息库。
  3. */
  4. "use strict";
  5. let configFile = require('../../include/commons').CONFIG_FILE;
  6. let config = require('../../resources/config/' + configFile);
  7. let ImDb = require('../mysql/db/im.db');
  8. let log = require('../../util/log.js');
  9. const DB_TABLES = require('../../include/commons').DB_TABLES;
  10. class MessageRepo {
  11. constructor() {
  12. }
  13. /**
  14. * 分页获取消息
  15. *
  16. * @param sessionId
  17. * @param page
  18. * @param size
  19. * @param handler
  20. */
  21. static findBySessionId(sessionId, page, size, handler) {
  22. if (page <= 0) {
  23. page = 1;
  24. }
  25. let session = new Sessions();
  26. session.getSessions(sessionId, function (err, res) {
  27. if (!err) {
  28. if (res.length == 0) {
  29. log.warn("Session is not found!");
  30. handler(null, null);
  31. return;
  32. }
  33. let type = res[0].type;
  34. let MessageTable = "";
  35. if (type == 1) {
  36. MessageTable = DB_TABLES.MucMessages;
  37. } else if (type == 2) {
  38. MessageTable = DB_TABLES.P2pMessages;
  39. } else {
  40. MessageTable = DB_TABLES.GroupMessages;
  41. }
  42. let sql = "select id, session_id, sender_id, sender_name, content_type, content, timestamp from " + MessageTable + " w where w.session_id = ? limit ?, ?";
  43. ImDb.execQuery({
  44. "sql": sessionsql,
  45. "args": [sessionId, page, size],
  46. "handler": function (err, res) {
  47. if (err) {
  48. log.error("sql:" + sql + "data:sessionId:" + sessionId);
  49. } else {
  50. log.info("getMessagesBySession success by sessionId :" + sessionId);
  51. }
  52. handler(err, res);
  53. }
  54. })
  55. }
  56. })
  57. }
  58. /**
  59. * 保存消息
  60. *
  61. * @param message 消息对象
  62. * @param sessionType 会话类型,1表示MUC会话,2表示P2P,3表示群会话,4表示临时讨论组
  63. * @param messageId
  64. * @param sessionId
  65. */
  66. static save(message, sessionType, messageId, sessionId, handler) {
  67. var sql = "INSERT INTO " + DB_TABLES.sessionTypeToTableName(sessionType) +
  68. " (id, session_id, sender_id, sender_name,content_type, content, timestamp) VALUES (?,?,?,?,?,?,?)";
  69. ImDb.execQuery({
  70. "sql": sql,
  71. "args": [messageId, sessionId, message.sender_id, message.sender_name, message.content_type, message.content, message.timestamp],
  72. "handler": handler
  73. });
  74. }
  75. }
  76. module.exports = MessageRepo;