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. }
  29. func on_bl_login_verify(ses nnet.ISession, pkt *RespPacket) {
  30. iwp, ok := g_rabbitProto.Get(pkt.Seq)
  31. if !ok {
  32. return // timeout
  33. }
  34. wp, ok := iwp.(*WaitParam)
  35. if !ok {
  36. log.Error("interface transform failed")
  37. return
  38. }
  39. if !wp.timer.Stop() {
  40. return // timeout
  41. }
  42. resp := &pb.VerifyResult{}
  43. err := mapstructure.Decode(pkt.Result, resp)
  44. if err != nil {
  45. response_c_login(wp.ses, pb.ErrCode_UNKNOWN, nil)
  46. log.Error("bad format", zap.Error(err))
  47. return
  48. }
  49. var s_login *pb.S_Login
  50. user, err := setget_user(resp)
  51. if err != nil {
  52. s_login = &pb.S_Login{
  53. UserId: resp.UserId,
  54. Username: resp.Username,
  55. Nickname: resp.Nickname,
  56. }
  57. } else {
  58. s_login = &pb.S_Login{
  59. UserId: user.UserId,
  60. Username: user.Username,
  61. Nickname: user.Nickname,
  62. }
  63. if user.Status != int32(pb.UserStatus_NORMAL) {
  64. response_c_login(wp.ses, pb.ErrCode_FORBIDDEN, nil)
  65. return
  66. }
  67. // check kick-off
  68. }
  69. response_c_login(wp.ses, pb.ErrCode_OK, s_login)
  70. }
  71. func setget_user(res *pb.VerifyResult) (*pb.User, error) {
  72. user, err := mod.LoadUser(res.UserId)
  73. if err != nil {
  74. if err == redis.Nil {
  75. user = &pb.User{
  76. UserId: res.UserId,
  77. Username: res.Username,
  78. Nickname: res.Nickname,
  79. HeaderIcon: res.HeaderIcon,
  80. Publish: res.Publish,
  81. Platform: res.Platform,
  82. }
  83. fields, err := mod.StructToMap(user)
  84. if err != nil {
  85. log.Error("", zap.Error(err))
  86. return user, nil
  87. }
  88. err = mod.UpdateUserAttrs(user.UserId, fields)
  89. if err != nil {
  90. log.Error("redis save", zap.Error(err))
  91. }
  92. return user, nil
  93. }
  94. log.Error("redis read", zap.Error(err))
  95. return nil, err
  96. }
  97. return user, nil
  98. }
  99. func on_bl_update_userinfo(ses nnet.ISession, pkt *RespPacket) {
  100. }