coder.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. var Message = require('pomelo-protocol').Message;
  2. var Constants = require('../../util/constants');
  3. var logger = require('pomelo-logger').getLogger('pomelo', __filename);
  4. var encode = function(reqId, route, msg) {
  5. if(!!reqId) {
  6. return composeResponse(this, reqId, route, msg);
  7. } else {
  8. return composePush(this, route, msg);
  9. }
  10. };
  11. var decode = function(msg) {
  12. msg = Message.decode(msg.body);
  13. var route = msg.route;
  14. // decode use dictionary
  15. if(!!msg.compressRoute) {
  16. if(!!this.connector.useDict) {
  17. var abbrs = this.dictionary.getAbbrs();
  18. if(!abbrs[route]) {
  19. logger.error('dictionary error! no abbrs for route : %s', route);
  20. return null;
  21. }
  22. route = msg.route = abbrs[route];
  23. } else {
  24. logger.error('fail to uncompress route code for msg: %j, server not enable dictionary.', msg);
  25. return null;
  26. }
  27. }
  28. // decode use protobuf
  29. if(!!this.protobuf && !!this.protobuf.getProtos().client[route]) {
  30. msg.body = this.protobuf.decode(route, msg.body);
  31. } else if(!!this.decodeIO_protobuf && !!this.decodeIO_protobuf.check(Constants.RESERVED.CLIENT, route)) {
  32. msg.body = this.decodeIO_protobuf.decode(route, msg.body);
  33. } else {
  34. msg.body = JSON.parse(msg.body.toString('utf8'));
  35. }
  36. return msg;
  37. };
  38. var composeResponse = function(server, msgId, route, msgBody) {
  39. if(!msgId || !route || !msgBody) {
  40. return null;
  41. }
  42. msgBody = encodeBody(server, route, msgBody);
  43. return Message.encode(msgId, Message.TYPE_RESPONSE, 0, null, msgBody);
  44. };
  45. var composePush = function(server, route, msgBody) {
  46. if(!route || !msgBody){
  47. return null;
  48. }
  49. msgBody = encodeBody(server, route, msgBody);
  50. // encode use dictionary
  51. var compressRoute = 0;
  52. if(!!server.dictionary) {
  53. var dict = server.dictionary.getDict();
  54. if(!!server.connector.useDict && !!dict[route]) {
  55. route = dict[route];
  56. compressRoute = 1;
  57. }
  58. }
  59. return Message.encode(0, Message.TYPE_PUSH, compressRoute, route, msgBody);
  60. };
  61. var encodeBody = function(server, route, msgBody) {
  62. // encode use protobuf
  63. if(!!server.protobuf && !!server.protobuf.getProtos().server[route]) {
  64. msgBody = server.protobuf.encode(route, msgBody);
  65. } else if(!!server.decodeIO_protobuf && !!server.decodeIO_protobuf.check(Constants.RESERVED.SERVER, route)) {
  66. msgBody = server.decodeIO_protobuf.encode(route, msgBody);
  67. } else {
  68. msgBody = new Buffer(JSON.stringify(msgBody), 'utf8');
  69. }
  70. return msgBody;
  71. };
  72. module.exports = {
  73. encode: encode,
  74. decode: decode
  75. };