123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- /**
- * 会话库。
- */
- "use strict";
- let ImDb = require('../mysql/db/im.db');
- let log = require('../../util/log.js');
- const DB_TABLES = require('../../include/commons').DB_TABLES;
- class SessionRepo {
- constructor() {
- }
- /**
- * 获取单个session对象
- *
- * @param sessionId
- * @param handler
- */
- static findOne(sessionId, handler) {
- let sessionSQL = "select id,name,type,create_date from " + DB_TABLES.Sessions + " s where s.id=?";
- ImDb.execQuery({
- "sql": sessionSQL,
- "args": [sessionId],
- "handler": function (err, res) {
- if (err) {
- log.error("sql:" + sessionSQL + "data:sessionId:" + sessionId);
- }
- handler(err, res);
- }
- });
- }
- /**
- * 获取用户全部会话
- *
- * @param userId
- * @param handler
- */
- static findAll(userId, handler) {
- let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
- let sessionSQL = "select id,name,type,create_date from " + DB_TABLES.Sessions + " s where s.id in(" + sql + ")";
- ImDb.execQuery({
- "sql": sessionSQL,
- "args": [userId],
- "handler": function (err, res) {
- if (err) {
- log.error("sql:" + sessionSQL + "data:userId:" + userId);
- } else {
- log.info("getUserSessionsFromMysql success by userId :" + userId);
- }
- handler(err, res);
- }
- });
- }
- /**
- * 获取用户置顶会话
- *
- * @param userId
- * @param handler
- */
- static findStickySessions(userId, handler) {
- let sql = "select session_id from " + DB_TABLES.Participants + " w where w.participant_id = ? group by w.session_id";
- 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 + ")";
- ImDb.execQuery({
- "sql": sessionSQL,
- "args": [userId],
- "handler": function (err, res) {
- if (err) {
- log.error("sql:" + sessionSQL + "data:userId:" + userId);
- }
-
- handler(err, res);
- }
- });
- }
- /**
- * 保存session。
- *
- * @param sessionId
- * @param name
- * @param type
- * @param createDate
- */
- static saveSession(sessionId, name, type, createDate) {
- let sql = "insert into " + DB_TABLES.Sessions + " (id,name,type,create_date) VALUES (?,?,?,?) ";
- ImDb.execQuery({
- "sql": sql,
- "args": [sessionId, name, type, createDate],
- "handler": function (err, res) {
- if (err) {
- log.error("sql:" + sql + "data:sessionId:" + sessionId + ",name:" + name + ",type:" + type + ",createDate:" + createDate);
- }
- }
- });
- }
- /**
- * 保存置顶会话。
- *
- * @param sessionId
- * @param user
- * @param score
- */
- static saveStickySession(sessionId, user, score) {
- let sql = "insert into " + DB_TABLES.StickySessions + " (user_id,session_id,score) VALUES (?,?,?) ";
- ImDb.execQuery({
- "sql": sql,
- "args": [user, sessionId, score],
- "handler": function (err, res) {
- if (err) {
- log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + user + ",score:" + score);
- }
- }
- });
- }
- /**
- * 取消会话置顶。
- *
- * @param sessionId
- * @param userId
- */
- static unstickSession(sessionId, userId) {
- let sql = "delete from " + DB_TABLES.StickySessions + " where user_id=? and session_id=? ";
- ImDb.execQuery({
- "sql": sql,
- "args": [userId, sessionId],
- "handler": function (err, res) {
- if (err) {
- log.error("sql:" + sql + "data:sessionId:" + sessionId + ",user:" + userId);
- }
- }
- });
- }
- }
- module.exports = SessionRepo;
|