rabbit_router.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. package main
  2. import (
  3. "git.wanbits.io/joe/franklin/mod"
  4. pb "git.wanbits.io/joe/franklin/protos"
  5. "git.wanbits.io/joe/kettle/log"
  6. "git.wanbits.io/joe/nnet"
  7. "github.com/go-redis/redis"
  8. "github.com/mitchellh/mapstructure"
  9. "go.uber.org/zap"
  10. )
  11. type fnRabbitCallback func(session nnet.ISession, packet *RespPacket)
  12. var (
  13. rabbit_route_table = map[string]fnRabbitCallback{
  14. CMD_HEARTBEAT: on_bl_heartbeat,
  15. CMD_LOGIN_VERIFY: on_bl_login_verify,
  16. CMD_UPDATE_USERINFO: on_bl_update_userinfo,
  17. }
  18. )
  19. func on_recv_timeout(cses nnet.ISession, pkt *ReqPacket) {
  20. switch pkt.Cmd {
  21. case CMD_LOGIN_VERIFY:
  22. response_c_login(cses, pb.ErrCode_TIMEOUT, nil)
  23. case CMD_UPDATE_USERINFO:
  24. log.Error("udpate userinfo timeout", zap.Any("param", pkt))
  25. }
  26. }
  27. func on_bl_heartbeat(ses nnet.ISession, pkt *RespPacket) {
  28. log.Debug("received bl_heartbeat from rabbit server")
  29. }
  30. func on_bl_login_verify(ses nnet.ISession, pkt *RespPacket) {
  31. iwp, ok := g_rabbitProto.Get(pkt.Seq)
  32. if !ok {
  33. return // timeout
  34. }
  35. wp, ok := iwp.(*WaitParam)
  36. if !ok {
  37. log.Error("interface transform failed")
  38. return
  39. }
  40. if !wp.timer.Stop() {
  41. return // timeout
  42. }
  43. resp := &pb.VerifyResult{}
  44. err := mapstructure.Decode(pkt.Result, resp)
  45. if err != nil {
  46. response_c_login(wp.ses, pb.ErrCode_UNKNOWN, nil)
  47. log.Error("bad format", zap.Error(err))
  48. return
  49. }
  50. var s_login *pb.S_Login
  51. user, err := setget_user(resp)
  52. if err != nil {
  53. s_login = &pb.S_Login{
  54. UserId: resp.UserId,
  55. Username: resp.Username,
  56. Nickname: resp.Nickname,
  57. }
  58. } else {
  59. s_login = &pb.S_Login{
  60. UserId: user.UserId,
  61. Username: user.Username,
  62. Nickname: user.Nickname,
  63. }
  64. if user.Status != int32(pb.UserStatus_NORMAL) {
  65. response_c_login(wp.ses, pb.ErrCode_FORBIDDEN, nil)
  66. return
  67. }
  68. // check kick-off
  69. }
  70. response_c_login(wp.ses, pb.ErrCode_OK, s_login)
  71. }
  72. func setget_user(res *pb.VerifyResult) (*pb.User, error) {
  73. user, err := mod.LoadUser(res.UserId)
  74. if err != nil {
  75. if err == redis.Nil {
  76. user = &pb.User{
  77. UserId: res.UserId,
  78. Username: res.Username,
  79. Nickname: res.Nickname,
  80. HeaderIcon: res.HeaderIcon,
  81. Publish: res.Publish,
  82. Platform: res.Platform,
  83. }
  84. fields, err := mod.StructToMap(user)
  85. if err != nil {
  86. log.Error("", zap.Error(err))
  87. return user, nil
  88. }
  89. err = mod.UpdateUserAttrs(user.UserId, fields)
  90. if err != nil {
  91. log.Error("redis save", zap.Error(err))
  92. }
  93. return user, nil
  94. }
  95. log.Error("redis read", zap.Error(err))
  96. return nil, err
  97. }
  98. return user, nil
  99. }
  100. func on_bl_update_userinfo(ses nnet.ISession, pkt *RespPacket) {
  101. }