playerMange.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502
  1. package service
  2. import (
  3. "context"
  4. "time"
  5. mhayaTime "github.com/mhaya/extend/time"
  6. "github.com/mhaya/game/game_cluster/internal/code"
  7. "github.com/mhaya/game/game_cluster/internal/constant"
  8. "github.com/mhaya/game/game_cluster/internal/mdb"
  9. "github.com/mhaya/game/game_cluster/internal/mdb/eventmodels"
  10. "github.com/mhaya/game/game_cluster/internal/mdb/models"
  11. "github.com/mhaya/game/game_cluster/nodes/webadmin/common"
  12. "github.com/mhaya/game/game_cluster/nodes/webadmin/entity"
  13. mhayaLogger "github.com/mhaya/logger"
  14. "go.mongodb.org/mongo-driver/bson"
  15. "go.mongodb.org/mongo-driver/mongo"
  16. "go.mongodb.org/mongo-driver/mongo/options"
  17. "gorm.io/gorm"
  18. )
  19. type PlayerManage struct {
  20. db *mongo.Database
  21. }
  22. func NewPlayerManage() *PlayerManage {
  23. return &PlayerManage{
  24. db: mdb.MDB,
  25. }
  26. }
  27. // 获取玩家列表
  28. func (a *PlayerManage) List(ctx context.Context, req entity.PlayerListReq) (*entity.PlayerListResp, *code.Result) {
  29. page, pageSize := checkPageParam(req.Page, req.Size)
  30. var registerRecords []*eventmodels.UserRegisterEventContent
  31. where := &eventmodels.UserRegisterEventContent{
  32. UserBasic: eventmodels.UserBasic{
  33. UserId: req.UserName,
  34. TgId: req.OpenId,
  35. XId: req.XID,
  36. ParentUserId: req.Pid,
  37. TonWall: req.TonWall,
  38. Email: req.Email,
  39. UserStatus: req.Status,
  40. },
  41. }
  42. db := mdb.LogstashDB.Model(&eventmodels.UserRegisterEventContent{}).Where(where).Order("create_at")
  43. if req.LevelMin > 0 && req.LevelMax == 0 {
  44. db = db.Where("level >= ? and level <= ?", req.LevelMin, 1000) // 等级最大值 暂定1000
  45. }
  46. if req.LevelMin > 0 && req.LevelMax > 0 && req.LevelMin <= req.LevelMax {
  47. db = db.Where("level >= ? and level <= ?", req.LevelMin, req.LevelMax)
  48. }
  49. if req.JoinTimeMin > 0 && req.JoinTimeMax > 0 && req.JoinTimeMin <= req.JoinTimeMax {
  50. db = db.Where("create_at >= ? and create_at <= ?", req.JoinTimeMin, req.JoinTimeMax)
  51. }
  52. pages := Paginate(db, page, pageSize)
  53. err := db.Scopes(pages.Limit).Find(&registerRecords).Error
  54. if err != nil && err != gorm.ErrRecordNotFound {
  55. mhayaLogger.Warnf("List Find error:%v", err)
  56. return nil, common.NewResult(code.InternalError)
  57. }
  58. var results []*entity.PlayerListDetail
  59. for _, v := range registerRecords {
  60. // 获取最新的用户信息更新记录
  61. var updateRecord *eventmodels.UserUpdateInfoEventContent
  62. updateWhere := &eventmodels.UserUpdateInfoEventContent{
  63. UserBasic: eventmodels.UserBasic{UserId: v.UserName, TgId: v.TgId},
  64. }
  65. err := mdb.LogstashDB.Model(&eventmodels.UserUpdateInfoEventContent{}).Where(updateWhere).Order("create_at desc").First(&updateRecord).Error
  66. if err != nil && err != gorm.ErrRecordNotFound {
  67. mhayaLogger.Warnf("List First updateRecord error:%v", err)
  68. return nil, common.NewResult(code.InternalError)
  69. }
  70. // 获取最新的用户登录记录
  71. var loginRecord *eventmodels.UserLoginEventContent
  72. loginWhere := &eventmodels.UserLoginEventContent{
  73. UserBasic: eventmodels.UserBasic{UserId: v.UserName, TgId: v.TgId},
  74. }
  75. err = mdb.LogstashDB.Model(&eventmodels.UserLoginEventContent{}).Where(loginWhere).Order("create_at desc").First(&loginRecord).Error
  76. if err != nil && err != gorm.ErrRecordNotFound {
  77. mhayaLogger.Warnf("List First loginRecord error:%v", err)
  78. return nil, common.NewResult(code.InternalError)
  79. }
  80. results = append(results, &entity.PlayerListDetail{
  81. UserName: v.UserId,
  82. OpenId: func() string {
  83. if updateRecord == nil {
  84. return v.TgId
  85. }
  86. return updateRecord.TgId
  87. }(),
  88. NickName: func() string {
  89. if updateRecord == nil {
  90. return v.UserName
  91. }
  92. return updateRecord.UserName
  93. }(),
  94. Pid: func() string {
  95. if updateRecord == nil {
  96. return v.ParentUserId
  97. }
  98. return updateRecord.ParentUserId
  99. }(),
  100. XID: func() string {
  101. if updateRecord == nil {
  102. return v.XId
  103. }
  104. return updateRecord.XId
  105. }(),
  106. TonWall: func() string {
  107. if updateRecord == nil {
  108. return v.TonWall
  109. }
  110. return updateRecord.TonWall
  111. }(),
  112. Email: func() string {
  113. if updateRecord == nil {
  114. return v.Email
  115. }
  116. return updateRecord.Email
  117. }(),
  118. Level: func() int {
  119. if updateRecord == nil {
  120. return v.Level
  121. }
  122. return updateRecord.Level
  123. }(),
  124. Status: func() int {
  125. if updateRecord == nil {
  126. return v.UserStatus
  127. }
  128. return updateRecord.UserStatus
  129. }(),
  130. LoginTime: func() int64 {
  131. if loginRecord != nil {
  132. return loginRecord.CreateAt
  133. }
  134. return 0
  135. }(),
  136. LoginIP: func() string {
  137. if loginRecord != nil {
  138. return loginRecord.Ip
  139. }
  140. return ""
  141. }(),
  142. JoinIP: v.Ip,
  143. JoinTime: v.CreateAt,
  144. })
  145. }
  146. return &entity.PlayerListResp{
  147. Details: results,
  148. Total: pages.Count,
  149. }, nil
  150. }
  151. // 获取的是注册的总人数
  152. func (a *PlayerManage) GetPlayerTotalCount() (int64, *code.Result) {
  153. where := &eventmodels.UserRegisterEventContent{
  154. EventBasic: eventmodels.EventBasic{
  155. Status: 0,
  156. },
  157. }
  158. db := mdb.LogstashDB.Model(&eventmodels.UserRegisterEventContent{}).Where(where).Order("create_at")
  159. var count int64
  160. err := db.Count(&count).Error
  161. if err != nil {
  162. mhayaLogger.Warnf("GetPlayerTotalCount Count error:%v", err)
  163. return 0, common.NewResult(code.InternalError)
  164. }
  165. return count, nil
  166. }
  167. // 获取的是登录过的总人数 根据user_id去重
  168. func (a *PlayerManage) GetLoginedPlayerTotalCount() (int64, *code.Result) {
  169. where := &eventmodels.UserLoginEventContent{
  170. EventBasic: eventmodels.EventBasic{
  171. Status: 0,
  172. },
  173. }
  174. db := mdb.LogstashDB.Model(&eventmodels.UserLoginEventContent{}).Distinct("user_id").Where(where)
  175. var count int64
  176. err := db.Count(&count).Error
  177. if err != nil {
  178. mhayaLogger.Warnf("GetLoginedPlayerTotalCount Count error:%v", err)
  179. return 0, common.NewResult(code.InternalError)
  180. }
  181. return count, nil
  182. }
  183. // 获取玩家详情
  184. func (a *PlayerManage) PlayerInfo(ctx context.Context, req entity.PlayerInfoReq) (*entity.PlayerInfoResp, *code.Result) {
  185. // 获取最新的用户信息更新记录
  186. var updateRecord *eventmodels.UserUpdateInfoEventContent
  187. updateWhere := &eventmodels.UserUpdateInfoEventContent{
  188. UserBasic: eventmodels.UserBasic{UserId: req.UserName},
  189. }
  190. err := mdb.LogstashDB.Model(&eventmodels.UserUpdateInfoEventContent{}).Where(updateWhere).Order("create_at desc").First(&updateRecord).Error
  191. if err != nil && err != gorm.ErrRecordNotFound {
  192. mhayaLogger.Warnf("PlayerInfo First updateRecord error:%v", err)
  193. return nil, common.NewResult(code.InternalError)
  194. }
  195. var registerRecord *eventmodels.UserRegisterEventContent
  196. if updateRecord == nil {
  197. where := &eventmodels.UserRegisterEventContent{
  198. UserBasic: eventmodels.UserBasic{UserId: req.UserName},
  199. }
  200. err := mdb.LogstashDB.Model(&eventmodels.UserRegisterEventContent{}).Where(where).First(&registerRecord).Error
  201. if err != nil && err != gorm.ErrRecordNotFound {
  202. mhayaLogger.Warnf("PlayerInfo First registerRecord error:%v", err)
  203. return nil, common.NewResult(code.InternalError)
  204. }
  205. }
  206. // 获取最新的用户登录记录
  207. var loginRecord *eventmodels.UserLoginEventContent
  208. loginWhere := &eventmodels.UserLoginEventContent{
  209. UserBasic: eventmodels.UserBasic{UserId: req.UserName},
  210. }
  211. err = mdb.LogstashDB.Model(&eventmodels.UserLoginEventContent{}).Where(loginWhere).Order("create_at desc").First(&loginRecord).Error
  212. if err != nil && err != gorm.ErrRecordNotFound {
  213. mhayaLogger.Warnf("PlayerInfo First loginRecord error:%v", err)
  214. return nil, common.NewResult(code.InternalError)
  215. }
  216. return &entity.PlayerInfoResp{
  217. UserName: func() string {
  218. if updateRecord != nil {
  219. return updateRecord.UserId
  220. }
  221. if registerRecord != nil {
  222. return registerRecord.UserId
  223. }
  224. return ""
  225. }(),
  226. OpenId: func() string {
  227. if updateRecord != nil {
  228. return updateRecord.TgId
  229. }
  230. if registerRecord != nil {
  231. return registerRecord.TgId
  232. }
  233. return ""
  234. }(),
  235. NickName: func() string {
  236. if updateRecord != nil {
  237. return updateRecord.UserName
  238. }
  239. if registerRecord != nil {
  240. return registerRecord.UserName
  241. }
  242. return ""
  243. }(),
  244. Pid: func() string {
  245. if updateRecord != nil {
  246. return updateRecord.ParentUserId
  247. }
  248. if registerRecord != nil {
  249. return registerRecord.ParentUserId
  250. }
  251. return ""
  252. }(),
  253. XID: func() string {
  254. if updateRecord != nil {
  255. return updateRecord.XId
  256. }
  257. if registerRecord != nil {
  258. return registerRecord.XId
  259. }
  260. return ""
  261. }(),
  262. TonWall: func() string {
  263. if updateRecord != nil {
  264. return updateRecord.TonWall
  265. }
  266. if registerRecord != nil {
  267. return registerRecord.TonWall
  268. }
  269. return ""
  270. }(),
  271. Email: func() string {
  272. if updateRecord != nil {
  273. return updateRecord.Email
  274. }
  275. if registerRecord != nil {
  276. return registerRecord.Email
  277. }
  278. return ""
  279. }(),
  280. Level: func() int {
  281. if updateRecord != nil {
  282. return updateRecord.Level
  283. }
  284. if registerRecord != nil {
  285. return registerRecord.Level
  286. }
  287. return 0
  288. }(),
  289. Status: func() int {
  290. if updateRecord != nil {
  291. return updateRecord.UserStatus
  292. }
  293. if registerRecord != nil {
  294. return registerRecord.UserStatus
  295. }
  296. return 0
  297. }(),
  298. LoginTime: func() int64 {
  299. if loginRecord != nil {
  300. return loginRecord.CreateAt
  301. }
  302. return 0
  303. }(),
  304. LoginIP: func() string {
  305. if loginRecord != nil {
  306. return loginRecord.Ip
  307. }
  308. return ""
  309. }(),
  310. JoinIP: func() string {
  311. if registerRecord != nil {
  312. return registerRecord.Ip
  313. }
  314. return ""
  315. }(),
  316. JoinTime: func() int64 {
  317. if registerRecord != nil {
  318. return registerRecord.CreateAt
  319. }
  320. return 0
  321. }(),
  322. Avatar: "",
  323. IsRobot: func() int {
  324. if updateRecord != nil && updateRecord.IsRobot {
  325. return 1
  326. }
  327. if registerRecord != nil && registerRecord.IsRobot {
  328. return 1
  329. }
  330. return 0
  331. }(),
  332. IsLeader: func() int {
  333. if updateRecord != nil && updateRecord.IsLeader {
  334. return 1
  335. }
  336. return 0
  337. }(),
  338. IsVip: func() int {
  339. if updateRecord != nil && updateRecord.IsVip {
  340. return 1
  341. }
  342. return 0
  343. }(),
  344. Successions: 0, // TODO
  345. MaxSuccessions: 0, // TODO
  346. PrevTime: func() int64 {
  347. if loginRecord != nil {
  348. return loginRecord.CreateAt
  349. }
  350. return 0
  351. }(),
  352. UpdateTime: func() int64 {
  353. if updateRecord != nil {
  354. return updateRecord.CreateAt
  355. }
  356. return 0
  357. }(),
  358. IsDrawShare: 0,
  359. DrawShareTime: 0,
  360. FirstReward: 0,
  361. // TODO 其他玩家信息
  362. }, nil
  363. }
  364. // 获取玩家中奖记录(默认查询最近三天)
  365. func (a *PlayerManage) RewardList(ctx context.Context, req entity.RewardListReq) (*entity.RewardListResp, *code.Result) {
  366. page, pageSize := checkPageParam(req.Page, req.Size)
  367. // 构建查询条件
  368. filter := bson.M{}
  369. if req.UserName != "" {
  370. filter["userName"] = bson.M{"$regex": escapeRegex(req.UserName), "$options": "i"}
  371. }
  372. filter["source"] = models.SourceDraw
  373. startTime := mhayaTime.Now().Add(-3 * 24 * time.Hour).Unix()
  374. endTime := mhayaTime.Now().Unix()
  375. if req.StartTime > 0 && req.StartTime >= startTime {
  376. if req.StartTime <= req.EndTime || req.EndTime == 0 {
  377. startTime = req.StartTime
  378. }
  379. }
  380. if req.EndTime > 0 && req.EndTime <= endTime {
  381. if req.StartTime <= req.EndTime {
  382. endTime = req.EndTime
  383. }
  384. }
  385. filter["createTime"] = bson.M{
  386. "$gte": startTime,
  387. "$lte": endTime,
  388. }
  389. // 设置分页选项
  390. skip := (page - 1) * pageSize
  391. limit := pageSize
  392. findOptions := options.Find().SetSkip(int64(skip)).SetLimit(int64(limit))
  393. collection := a.db.Collection(constant.CNamePlayerReward)
  394. // 获取总数total
  395. count, err := collection.CountDocuments(ctx, filter)
  396. if err != nil {
  397. mhayaLogger.Warnf("RewardList count error:%v", err)
  398. return nil, common.NewResult(code.InternalError)
  399. }
  400. // 执行查询
  401. cursor, err := collection.Find(ctx, filter, findOptions)
  402. if err != nil {
  403. mhayaLogger.Warnf("RewardList Find error:%v", err)
  404. return nil, common.NewResult(code.InternalError)
  405. }
  406. defer func() {
  407. if closeErr := cursor.Close(ctx); closeErr != nil {
  408. mhayaLogger.Warnf("Error closing cursor: %v", closeErr)
  409. }
  410. }()
  411. // 解析结果
  412. results := make([]*models.ToPlayerRewardBase, 0)
  413. for cursor.Next(ctx) {
  414. var result models.PlayerRewardBase
  415. if err := cursor.Decode(&result); err != nil {
  416. mhayaLogger.Warnf("RewardList Decode error:%v", err)
  417. return nil, common.NewResult(code.InternalError)
  418. }
  419. results = append(results, result.To())
  420. }
  421. if err := cursor.Err(); err != nil {
  422. mhayaLogger.Warnf("RewardList cursor error:%v", err)
  423. return nil, common.NewResult(code.InternalError)
  424. }
  425. return &entity.RewardListResp{
  426. Details: results,
  427. Total: count,
  428. }, nil
  429. }