msg_group.js 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. var express = require('express');
  2. var router = express.Router();
  3. var msg_group = require("../models/msg_group");
  4. var msg_statistic = require("../models/msg_statistic");
  5. var user = require("../models/user");
  6. var push = require("../models/push_notify");
  7. var http = require('http');
  8. var qs = require('querystring');
  9. var getui = require('getui');
  10. /**
  11. * 群组消息:group/sendmsg.im?from_uid=x&to_gid=xx&content=xxx&type=1&at_uid=xxxx&group_type
  12. * 参数:
  13. * from_uid:发送者id
  14. * to_gid:群组id
  15. * content:消息内容
  16. * type:消息类型:1文本,2图片,3语音
  17. * at_uid:@用户id:1为行政组,null或者其他值为自定义组
  18. * group_type:区分是行政组还是自定义组,从不同表中查找组成员
  19. */
  20. router.get('/sendmsg.im', function (req, res, next) {
  21. if (req.query.from_uid == null
  22. || req.query.to_gid == null
  23. || req.query.content == null
  24. || req.query.type == null) {
  25. res.send({errno: -1, errmsg: 'parameter error'});
  26. return;
  27. }
  28. msg_group.isGroupUser(req.query.from_uid, req.query.to_gid, req.query.group_type, function (err, result) {
  29. if (err) {
  30. res.send({errno: 1, errmsg: 'get users from db error'});
  31. return;
  32. }
  33. if (result.length == 0) {
  34. res.send({errno: 2, errmsg: 'no receive users'});
  35. return;
  36. }
  37. var at_uid = '';
  38. if (req.query.at_uid != null) {
  39. at_uid = req.query.at_uid;
  40. }
  41. // 保存群组消息
  42. msg_group.saveGroupMsg(req.query.from_uid, req.query.to_gid, at_uid, req.query.type, req.query.content, function (err, result) {
  43. if (err) {
  44. res.send({errno: 3, errmsg: 'save msg to db error'});
  45. return;
  46. }
  47. res.send({errno: 0, errmsg: 'send group msg success'});
  48. // 统计信息
  49. msg_statistic.updateGroupChatInfo(req.query.from_uid,
  50. req.query.to_gid,
  51. req.query.from_uid,
  52. 0,
  53. req.query.type,
  54. req.query.content,
  55. false,
  56. function (err, result) {
  57. if (err) {
  58. console.log(err);
  59. }
  60. });
  61. // 推送通知消息给群组各成员
  62. msg_group.getGroupUsers(req.query.to_gid, req.query.group_type, function (err, result) {
  63. if (err) {
  64. console.log('get users from db error');
  65. return;
  66. }
  67. if (result.length == 0) {
  68. console.log('no receive users');
  69. return;
  70. }
  71. // 推送通知
  72. for (var nIndex = 0; nIndex < result.length; nIndex++) {
  73. if (result[nIndex].member_code == req.query.from_uid) {
  74. continue;
  75. }
  76. (function () {
  77. var toUserID = result[nIndex].member_code;
  78. user.getUserbyID(toUserID, function (err, result) {
  79. var tmp = toUserID;
  80. if (err) {
  81. console.log('group msg:get user by id from db failed');
  82. return;
  83. }
  84. var title = '';
  85. var content = '';
  86. if (req.query.type == 1) {
  87. title = '群组消息';
  88. content = req.query.content;
  89. } else if (req.query.type == 2) {
  90. title = '群组消息';
  91. content = '接收到 [图片]';
  92. } else if (req.query.type == 3) {
  93. title = '群组消息';
  94. content = '接收到 [语音]';
  95. } else {
  96. title = '群组消息';
  97. content = '接收到一条新消息';
  98. }
  99. var bMustPush = 0;
  100. var data;
  101. if (result.length > 0) {
  102. data = result[0];
  103. if (data.is_online) {
  104. bMustPush = 1;
  105. }
  106. }
  107. var push_data = JSON.stringify({
  108. type:'group_msg',
  109. gid:req.query.to_gid
  110. });
  111. // 保存通知到数据库中
  112. push.savePushNotify(toUserID,
  113. req.query.type,
  114. title,
  115. content,
  116. push_data,
  117. bMustPush,
  118. function (err, result) {
  119. if (err) {
  120. // 保存失败
  121. console.log('save msg to db failed');
  122. } else {
  123. console.log('save msg to db success');
  124. if (bMustPush == true) {
  125. if (data.platform == 0) {// iOS
  126. getui.pushAPN(toUserID,
  127. data.token,
  128. req.query.type,
  129. title,
  130. content,
  131. push_data,
  132. function (err, result) {
  133. if (err != null) {
  134. console.log(err);
  135. } else {
  136. console.log(result);
  137. }
  138. });
  139. } else {// Android
  140. getui.pushAndroid(data.client_id,
  141. req.query.type,
  142. title,
  143. content,
  144. push_data,
  145. data.status,
  146. function (err, result) {
  147. if (err != null) {
  148. console.log(err);
  149. } else {
  150. console.log(result);
  151. }
  152. });
  153. }
  154. }
  155. }
  156. });
  157. });
  158. // 统计信息
  159. var at_me = 0;
  160. if (at_uid == toUserID) {
  161. at_me = 1;
  162. }
  163. msg_statistic.updateGroupChatInfo(toUserID,
  164. req.query.to_gid,
  165. req.query.from_uid,
  166. at_me,
  167. req.query.type,
  168. req.query.content,
  169. true,
  170. function (err, result) {
  171. if (err) {
  172. console.log(err);
  173. }
  174. });
  175. })();
  176. }
  177. });
  178. });
  179. });
  180. });
  181. /**
  182. * 群组消息:group/getmsg.im?uid=x&gid=xx&start=0&count=20
  183. * 参数:
  184. * uid:用户id
  185. * gid:群组id
  186. * start;分页查询起始条目
  187. * count:查询条数
  188. * 备注:按时间倒序
  189. */
  190. router.get('/getmsg.im', function (req, res, next) {
  191. if (req.query.uid == null
  192. || req.query.gid == null
  193. || req.query.start == null
  194. || req.query.count == null) {
  195. res.send({errno: -1, errmsg: 'parameter error'});
  196. return;
  197. }
  198. msg_group.getGroupMsg(req.query.gid, req.query.start, req.query.count, function (err, result) {
  199. if (err) {
  200. res.send({errno: 1, errmsg: 'get group msg from db error'});
  201. return;
  202. }
  203. var data = {};
  204. data.start = parseInt(req.query.start);
  205. data.count = result.length;
  206. data.list = new Array();
  207. for (var nIndex = 0; nIndex < result.length; nIndex++) {
  208. result[nIndex].timestamp = Date.parse(new Date(result[nIndex].timestamp));
  209. data.list.push(result[nIndex]);
  210. }
  211. res.send(data);
  212. // 清空统计信息
  213. msg_statistic.clearGroupChatInfo(req.query.uid,
  214. req.query.gid,
  215. function (err, result) {
  216. if (err) {
  217. console.log(err);
  218. }
  219. });
  220. });
  221. });
  222. module.exports = router;