playerMange.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687
  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) GetMaxSuccessions(userName string) (int64, *code.Result) {
  153. loginWhere := &eventmodels.UserLoginEventContent{
  154. UserBasic: eventmodels.UserBasic{
  155. UserId: userName,
  156. },
  157. }
  158. loginDb := mdb.LogstashDB.Model(&eventmodels.UserLoginEventContent{}).Where(loginWhere).Order("create_at")
  159. var loginCount int64
  160. err := loginDb.Count(&loginCount).Error
  161. if err != nil {
  162. mhayaLogger.Warnf("GetMaxSuccessions loginCount error:%v", err)
  163. return 0, common.NewResult(code.InternalError)
  164. }
  165. return loginCount, nil
  166. }
  167. // 获取用户骰子点击次数
  168. func (a *PlayerManage) GetDiceHits(userName string) (int64, *code.Result) {
  169. diceClickWhere := &eventmodels.ClickEventContent{
  170. UserBasic: eventmodels.UserBasic{
  171. UserId: userName,
  172. },
  173. ClickName: string(constant.DiceClickName),
  174. }
  175. clickDb := mdb.LogstashDB.Model(&eventmodels.ClickEventContent{}).Where(diceClickWhere).Order("create_at")
  176. var diceHits int64
  177. err := clickDb.Count(&diceHits).Error
  178. if err != nil {
  179. mhayaLogger.Warnf("GetDiceHits diceHits error:%v", err)
  180. return 0, common.NewResult(code.InternalError)
  181. }
  182. return diceHits, nil
  183. }
  184. // 获取邀请点击次数
  185. func (a *PlayerManage) GetInvitationHits(userName string) (int64, *code.Result) {
  186. inviteClickWhere := &eventmodels.ClickEventContent{
  187. UserBasic: eventmodels.UserBasic{
  188. UserId: userName,
  189. },
  190. ClickName: string(constant.InviteClickName),
  191. }
  192. clickDb := mdb.LogstashDB.Model(&eventmodels.ClickEventContent{}).Where(inviteClickWhere).Order("create_at")
  193. var invitationHits int64
  194. err := clickDb.Count(&invitationHits).Error
  195. if err != nil {
  196. mhayaLogger.Warnf("GetInvitationHits invitationHits error:%v", err)
  197. return 0, common.NewResult(code.InternalError)
  198. }
  199. return invitationHits, nil
  200. }
  201. // 获取转盘点击次数
  202. func (a *PlayerManage) GetTurntableClicks(userName string) (int64, *code.Result) {
  203. turntableClickWhere := &eventmodels.ClickEventContent{
  204. UserBasic: eventmodels.UserBasic{
  205. UserId: userName,
  206. },
  207. ClickName: string(constant.TurntableClickName),
  208. }
  209. clickDb := mdb.LogstashDB.Model(&eventmodels.ClickEventContent{}).Where(turntableClickWhere).Order("create_at")
  210. var turntableClicks int64
  211. err := clickDb.Count(&turntableClicks).Error
  212. if err != nil {
  213. mhayaLogger.Warnf("GetTurntableClicks turntableClicks error:%v", err)
  214. return 0, common.NewResult(code.InternalError)
  215. }
  216. return turntableClicks, nil
  217. }
  218. // 获取转盘实际抽奖次数
  219. func (a *PlayerManage) GetTurntableRuns(userName string) (int64, *code.Result) {
  220. turntableWhere := &eventmodels.TurntableEventContent{
  221. UserBasic: eventmodels.UserBasic{
  222. UserId: userName,
  223. },
  224. }
  225. turntableDb := mdb.LogstashDB.Model(&eventmodels.TurntableEventContent{}).Where(turntableWhere).Order("create_at")
  226. var turntableRuns int64
  227. err := turntableDb.Count(&turntableRuns).Error
  228. if err != nil {
  229. mhayaLogger.Warnf("GetTurntableRuns turntableRuns error:%v", err)
  230. return 0, common.NewResult(code.InternalError)
  231. }
  232. return turntableRuns, nil
  233. }
  234. // 获取邀请成功人数 status:查询的事件状态
  235. func (a *PlayerManage) GetSuccessfulInvitations(userName string, status int) (int64, *code.Result) {
  236. inviteWhere := &eventmodels.InviteEventContent{
  237. UserBasic: eventmodels.UserBasic{
  238. UserId: userName,
  239. },
  240. EventBasic: eventmodels.EventBasic{
  241. Status: status,
  242. },
  243. }
  244. inviteDb := mdb.LogstashDB.Model(&eventmodels.InviteEventContent{}).Where(inviteWhere).Order("create_at")
  245. var successfulInvitations int64
  246. err := inviteDb.Count(&successfulInvitations).Error
  247. if err != nil {
  248. mhayaLogger.Warnf("GetSuccessfulInvitations successfulInvitations error:%v", err)
  249. return 0, common.NewResult(code.InternalError)
  250. }
  251. return successfulInvitations, nil
  252. }
  253. // 获取提现次数 status:查询的事件状态
  254. func (a *PlayerManage) GetWithdrawalCount(userName string, status int) (int64, *code.Result) {
  255. withdrawalWhere := &eventmodels.UserWithdrawEventContent{
  256. UserBasic: eventmodels.UserBasic{
  257. UserId: userName,
  258. },
  259. EventBasic: eventmodels.EventBasic{
  260. Status: status,
  261. },
  262. }
  263. withdrawalDb := mdb.LogstashDB.Model(&eventmodels.UserWithdrawEventContent{}).Where(withdrawalWhere).Order("create_at")
  264. var withdrawals int64
  265. err := withdrawalDb.Count(&withdrawals).Error
  266. if err != nil {
  267. mhayaLogger.Warnf("GetWithdrawalCount withdrawals error:%v", err)
  268. return 0, common.NewResult(code.InternalError)
  269. }
  270. return withdrawals, nil
  271. }
  272. // 获取累计提现金额 currency:货币类型 status:查询的事件状态
  273. func (a *PlayerManage) GetCumulativeWithdrawalAmount(userName, currency string, status int) (int64, *code.Result) {
  274. withdrawalAmountWhere := &eventmodels.UserWithdrawEventContent{
  275. UserBasic: eventmodels.UserBasic{
  276. UserId: userName,
  277. },
  278. EventBasic: eventmodels.EventBasic{
  279. Status: status,
  280. },
  281. Currency: currency,
  282. }
  283. var cumulativeWithdrawalAmount int64
  284. err := mdb.LogstashDB.Model(&eventmodels.UserWithdrawEventContent{}).Where(withdrawalAmountWhere).Pluck("SUM(amount) as total_amount", &cumulativeWithdrawalAmount).Error
  285. if err != nil {
  286. mhayaLogger.Warnf("GetCumulativeWithdrawalAmount Pluck currency error:%v", err)
  287. return 0, common.NewResult(code.InternalError)
  288. }
  289. return cumulativeWithdrawalAmount, nil
  290. }
  291. // 获取的是注册的总人数
  292. func (a *PlayerManage) GetPlayerTotalCount() (int64, *code.Result) {
  293. where := &eventmodels.UserRegisterEventContent{
  294. EventBasic: eventmodels.EventBasic{
  295. Status: 0,
  296. },
  297. }
  298. db := mdb.LogstashDB.Model(&eventmodels.UserRegisterEventContent{}).Where(where).Order("create_at")
  299. var count int64
  300. err := db.Count(&count).Error
  301. if err != nil {
  302. mhayaLogger.Warnf("GetPlayerTotalCount Count error:%v", err)
  303. return 0, common.NewResult(code.InternalError)
  304. }
  305. return count, nil
  306. }
  307. // 获取的是登录过的总人数 根据user_id去重
  308. func (a *PlayerManage) GetLoginedPlayerTotalCount() (int64, *code.Result) {
  309. where := &eventmodels.UserLoginEventContent{
  310. EventBasic: eventmodels.EventBasic{
  311. Status: 0,
  312. },
  313. }
  314. db := mdb.LogstashDB.Model(&eventmodels.UserLoginEventContent{}).Distinct("user_id").Where(where)
  315. var count int64
  316. err := db.Count(&count).Error
  317. if err != nil {
  318. mhayaLogger.Warnf("GetLoginedPlayerTotalCount Count error:%v", err)
  319. return 0, common.NewResult(code.InternalError)
  320. }
  321. return count, nil
  322. }
  323. // 获取最新的用户信息更新记录
  324. func (a *PlayerManage) GetPlayerLastestUpdateRecord(userName string) (*eventmodels.UserUpdateInfoEventContent, *code.Result) {
  325. var updateRecord *eventmodels.UserUpdateInfoEventContent
  326. updateWhere := &eventmodels.UserUpdateInfoEventContent{
  327. UserBasic: eventmodels.UserBasic{UserId: userName},
  328. }
  329. err := mdb.LogstashDB.Model(&eventmodels.UserUpdateInfoEventContent{}).Where(updateWhere).Order("create_at desc").First(&updateRecord).Error
  330. if err != nil && err != gorm.ErrRecordNotFound {
  331. mhayaLogger.Warnf("GetPlayerLastestUpdateRecord First updateRecord error:%v", err)
  332. return nil, common.NewResult(code.InternalError)
  333. }
  334. return updateRecord, nil
  335. }
  336. func (a *PlayerManage) GetPlayerRegisterRecord(userName string) (*eventmodels.UserRegisterEventContent, *code.Result) {
  337. var registerRecord *eventmodels.UserRegisterEventContent
  338. where := &eventmodels.UserRegisterEventContent{
  339. UserBasic: eventmodels.UserBasic{UserId: userName},
  340. }
  341. err := mdb.LogstashDB.Model(&eventmodels.UserRegisterEventContent{}).Where(where).First(&registerRecord).Error
  342. if err != nil && err != gorm.ErrRecordNotFound {
  343. mhayaLogger.Warnf("GetPlayerRegisterRecord First registerRecord error:%v", err)
  344. return nil, common.NewResult(code.InternalError)
  345. }
  346. return registerRecord, nil
  347. }
  348. // 获取玩家详情
  349. func (a *PlayerManage) PlayerInfo(ctx context.Context, req entity.PlayerInfoReq) (*entity.PlayerInfoResp, *code.Result) {
  350. // 获取最新的用户信息更新记录
  351. var updateRecord *eventmodels.UserUpdateInfoEventContent
  352. updateWhere := &eventmodels.UserUpdateInfoEventContent{
  353. UserBasic: eventmodels.UserBasic{UserId: req.UserName},
  354. }
  355. err := mdb.LogstashDB.Model(&eventmodels.UserUpdateInfoEventContent{}).Where(updateWhere).Order("create_at desc").First(&updateRecord).Error
  356. if err != nil && err != gorm.ErrRecordNotFound {
  357. mhayaLogger.Warnf("PlayerInfo First updateRecord error:%v", err)
  358. return nil, common.NewResult(code.InternalError)
  359. }
  360. var registerRecord *eventmodels.UserRegisterEventContent
  361. if updateRecord == nil {
  362. where := &eventmodels.UserRegisterEventContent{
  363. UserBasic: eventmodels.UserBasic{UserId: req.UserName},
  364. }
  365. err := mdb.LogstashDB.Model(&eventmodels.UserRegisterEventContent{}).Where(where).First(&registerRecord).Error
  366. if err != nil && err != gorm.ErrRecordNotFound {
  367. mhayaLogger.Warnf("PlayerInfo First registerRecord error:%v", err)
  368. return nil, common.NewResult(code.InternalError)
  369. }
  370. }
  371. // 获取最新的用户登录记录
  372. var loginRecord *eventmodels.UserLoginEventContent
  373. loginWhere := &eventmodels.UserLoginEventContent{
  374. UserBasic: eventmodels.UserBasic{UserId: req.UserName},
  375. }
  376. err = mdb.LogstashDB.Model(&eventmodels.UserLoginEventContent{}).Where(loginWhere).Order("create_at desc").First(&loginRecord).Error
  377. if err != nil && err != gorm.ErrRecordNotFound {
  378. mhayaLogger.Warnf("PlayerInfo First loginRecord error:%v", err)
  379. return nil, common.NewResult(code.InternalError)
  380. }
  381. return &entity.PlayerInfoResp{
  382. UserName: func() string {
  383. if updateRecord != nil {
  384. return updateRecord.UserId
  385. }
  386. if registerRecord != nil {
  387. return registerRecord.UserId
  388. }
  389. return ""
  390. }(),
  391. OpenId: func() string {
  392. if updateRecord != nil {
  393. return updateRecord.TgId
  394. }
  395. if registerRecord != nil {
  396. return registerRecord.TgId
  397. }
  398. return ""
  399. }(),
  400. NickName: func() string {
  401. if updateRecord != nil {
  402. return updateRecord.UserName
  403. }
  404. if registerRecord != nil {
  405. return registerRecord.UserName
  406. }
  407. return ""
  408. }(),
  409. Pid: func() string {
  410. if updateRecord != nil {
  411. return updateRecord.ParentUserId
  412. }
  413. if registerRecord != nil {
  414. return registerRecord.ParentUserId
  415. }
  416. return ""
  417. }(),
  418. XID: func() string {
  419. if updateRecord != nil {
  420. return updateRecord.XId
  421. }
  422. if registerRecord != nil {
  423. return registerRecord.XId
  424. }
  425. return ""
  426. }(),
  427. TonWall: func() string {
  428. if updateRecord != nil {
  429. return updateRecord.TonWall
  430. }
  431. if registerRecord != nil {
  432. return registerRecord.TonWall
  433. }
  434. return ""
  435. }(),
  436. Email: func() string {
  437. if updateRecord != nil {
  438. return updateRecord.Email
  439. }
  440. if registerRecord != nil {
  441. return registerRecord.Email
  442. }
  443. return ""
  444. }(),
  445. Level: func() int {
  446. if updateRecord != nil {
  447. return updateRecord.Level
  448. }
  449. if registerRecord != nil {
  450. return registerRecord.Level
  451. }
  452. return 0
  453. }(),
  454. Status: func() int {
  455. if updateRecord != nil {
  456. return updateRecord.UserStatus
  457. }
  458. if registerRecord != nil {
  459. return registerRecord.UserStatus
  460. }
  461. return 0
  462. }(),
  463. LoginTime: func() int64 {
  464. if loginRecord != nil {
  465. return loginRecord.CreateAt
  466. }
  467. return 0
  468. }(),
  469. LoginIP: func() string {
  470. if loginRecord != nil {
  471. return loginRecord.Ip
  472. }
  473. return ""
  474. }(),
  475. JoinIP: func() string {
  476. if registerRecord != nil {
  477. return registerRecord.Ip
  478. }
  479. return ""
  480. }(),
  481. JoinTime: func() int64 {
  482. if registerRecord != nil {
  483. return registerRecord.CreateAt
  484. }
  485. return 0
  486. }(),
  487. Avatar: "",
  488. IsRobot: func() int {
  489. if updateRecord != nil && updateRecord.IsRobot {
  490. return 1
  491. }
  492. if registerRecord != nil && registerRecord.IsRobot {
  493. return 1
  494. }
  495. return 0
  496. }(),
  497. IsLeader: func() int {
  498. if updateRecord != nil && updateRecord.IsLeader {
  499. return 1
  500. }
  501. return 0
  502. }(),
  503. IsVip: func() int {
  504. if updateRecord != nil && updateRecord.IsVip {
  505. return 1
  506. }
  507. return 0
  508. }(),
  509. Successions: 0, // TODO
  510. MaxSuccessions: 0, // TODO
  511. PrevTime: func() int64 {
  512. if loginRecord != nil {
  513. return loginRecord.CreateAt
  514. }
  515. return 0
  516. }(),
  517. UpdateTime: func() int64 {
  518. if updateRecord != nil {
  519. return updateRecord.CreateAt
  520. }
  521. return 0
  522. }(),
  523. IsDrawShare: 0,
  524. DrawShareTime: 0,
  525. FirstReward: 0,
  526. // TODO 其他玩家信息
  527. }, nil
  528. }
  529. // 获取玩家中奖记录(默认查询最近三天)
  530. func (a *PlayerManage) RewardList(ctx context.Context, req entity.RewardListReq) (*entity.RewardListResp, *code.Result) {
  531. page, pageSize := checkPageParam(req.Page, req.Size)
  532. // 构建查询条件
  533. filter := bson.M{}
  534. if req.UserName != "" {
  535. filter["userName"] = bson.M{"$regex": escapeRegex(req.UserName), "$options": "i"}
  536. }
  537. filter["source"] = models.SourceDraw
  538. startTime := mhayaTime.Now().Add(-3 * 24 * time.Hour).Unix()
  539. endTime := mhayaTime.Now().Unix()
  540. if req.StartTime > 0 && req.StartTime >= startTime {
  541. if req.StartTime <= req.EndTime || req.EndTime == 0 {
  542. startTime = req.StartTime
  543. }
  544. }
  545. if req.EndTime > 0 && req.EndTime <= endTime {
  546. if req.StartTime <= req.EndTime {
  547. endTime = req.EndTime
  548. }
  549. }
  550. filter["createTime"] = bson.M{
  551. "$gte": startTime,
  552. "$lte": endTime,
  553. }
  554. // 设置分页选项
  555. skip := (page - 1) * pageSize
  556. limit := pageSize
  557. findOptions := options.Find().SetSkip(int64(skip)).SetLimit(int64(limit))
  558. collection := a.db.Collection(constant.CNamePlayerReward)
  559. // 获取总数total
  560. count, err := collection.CountDocuments(ctx, filter)
  561. if err != nil {
  562. mhayaLogger.Warnf("RewardList count error:%v", err)
  563. return nil, common.NewResult(code.InternalError)
  564. }
  565. // 执行查询
  566. cursor, err := collection.Find(ctx, filter, findOptions)
  567. if err != nil {
  568. mhayaLogger.Warnf("RewardList Find error:%v", err)
  569. return nil, common.NewResult(code.InternalError)
  570. }
  571. defer func() {
  572. if closeErr := cursor.Close(ctx); closeErr != nil {
  573. mhayaLogger.Warnf("Error closing cursor: %v", closeErr)
  574. }
  575. }()
  576. // 解析结果
  577. results := make([]*models.ToPlayerRewardBase, 0)
  578. for cursor.Next(ctx) {
  579. var result models.PlayerRewardBase
  580. if err := cursor.Decode(&result); err != nil {
  581. mhayaLogger.Warnf("RewardList Decode error:%v", err)
  582. return nil, common.NewResult(code.InternalError)
  583. }
  584. results = append(results, result.To())
  585. }
  586. if err := cursor.Err(); err != nil {
  587. mhayaLogger.Warnf("RewardList cursor error:%v", err)
  588. return nil, common.NewResult(code.InternalError)
  589. }
  590. return &entity.RewardListResp{
  591. Details: results,
  592. Total: count,
  593. }, nil
  594. }