message.repo.js 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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 messages 消息对象
  62. * @param sessionType 会话类型,1表示MUC会话,2表示P2P,3表示群会话,4表示临时讨论组
  63. * @param messageId
  64. * @param sessionId
  65. */
  66. static save(messages, sessionType, messageId, sessionId) {
  67. var sql = "INSERT INTO " + DB_TABLES.sesstionTypeToTableName(sessionType) +
  68. " (id, session_id, sender_id, sender_name,content_type, content, timestamp) VALUES (?,?,?,?,?,?,?)";
  69. ImDb.execQuery({
  70. "sql": sql,
  71. "args": [messageId, sessionId, messages.senderId, messages.senderName, messages.contentType, messages.content, messages.timestamp],
  72. "handler": function (err, res) {
  73. if (err) {
  74. log.error("sql:" + sql + ",error:" + err + ",data:" + JSON.stringify(messages) + ",messageid:" + messageId + ",sessionId:" + sessionId);
  75. } else {
  76. log.info("save message to mysql is success by session :" + sessionId);
  77. }
  78. }
  79. });
  80. }
  81. }
  82. module.exports = MessageRepo;