Plantask.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. <?php
  2. namespace app\index\controller;
  3. use think\Controller;
  4. use Redis;
  5. use think\Db;
  6. use app\common\library\Easemob;
  7. class Plantask extends Controller
  8. {
  9. //关于本文件里的计划任务
  10. //只有 public 方法,auto_开头的才是计划任务,其他private 方法都是工具方法
  11. ////////////////////////////////////////下面都是计划任务方法///////////////////////////////////////////////////////////////
  12. //自动删除3天前的爆币日志,提升统计速度
  13. public function auto_del_baobi_log(){
  14. $today_start = strtotime(date('Y-m-d')) - (86400 * 3);
  15. $map = [
  16. 'createtime' => ['lt',$today_start],
  17. ];
  18. Db::name('gift_baobi_log')->where($map)->delete();
  19. }
  20. //送礼物(api/party/giveGiftToYou)拆分出来的异步用户升级方法,
  21. //最新方法
  22. public function auto_user_level_up(){
  23. Db::startTrans();
  24. $tasklist = Db::name('gift_user_party')->where('task_status',0)->order('id asc')->field('party_id')->select();
  25. if(empty($tasklist)){
  26. Db::rollback();
  27. echo 'empty';
  28. exit;
  29. }
  30. try {
  31. //redis
  32. $redis = new Redis();
  33. $redisconfig = config("redis");
  34. $redis->connect($redisconfig["host"], $redisconfig["port"]);
  35. if ($redisconfig['redis_pwd']) {
  36. $redis->auth($redisconfig['redis_pwd']);
  37. }
  38. if($redisconfig['redis_selectdb'] > 0){
  39. $redis->select($redisconfig['redis_selectdb']);
  40. }
  41. //开始
  42. $party_ids = array_column($tasklist,'party_id');
  43. $party_ids = array_flip($party_ids);
  44. $party_ids = array_flip($party_ids);
  45. //dump($party_ids);
  46. $partyInfo_arr = Db::name('party')->where('id','IN',$party_ids)->column('id,user_id,easemob_room_id');
  47. //dump($partyInfo_arr);exit;
  48. foreach($partyInfo_arr as $party_id => $partyInfo){
  49. //更新麦位魅力值
  50. $this->updateSeatCharm($partyInfo['easemob_room_id'],$partyInfo,$redis);
  51. }
  52. //结束
  53. $rs_up = Db::name('gift_user_party')->where('party_id','IN',$party_ids)->update(['task_status'=>1]);
  54. Db::commit();
  55. } catch (ValidateException $e) {
  56. Db::rollback();
  57. $this->error($e->getMessage());
  58. } catch (PDOException $e) {
  59. Db::rollback();
  60. $this->error($e->getMessage());
  61. } catch (Exception $e) {
  62. Db::rollback();
  63. $this->error($e->getMessage());
  64. }
  65. }
  66. /////////////////////////////////////////下面都是工具方法////////////////////////////////////////////////
  67. /**
  68. * 用户赠送礼物后房间内麦位魅力值增加,更新到麦位自定义信息
  69. * $seatnum 座位数字 1,不是键名 seat1
  70. */
  71. private function updateSeatCharm($easemob_room_id,$party_info,$redis) {
  72. //获取已有信息
  73. $easemob = new Easemob();
  74. $seatlist = $easemob->room_getRoomCustomAttribute($easemob_room_id,['seat0','seat1','seat2','seat3','seat4','seat5','seat6','seat7']);
  75. if(empty($seatlist)){
  76. return true;
  77. }
  78. $matedata = [];
  79. // 获取用户魅力值
  80. $users = $redis->zRevRange("hourCharm_".$party_info['id'],0,-1,true);
  81. //轮询麦位
  82. foreach($seatlist as $seatnum => $seatdata){
  83. $seatdata = json_decode($seatdata,true);
  84. if($users) {
  85. foreach($users as $user_id => $charm){
  86. if(isset($seatdata['userNo']) && $seatdata['userNo'] == $user_id){
  87. $seatdata['charm'] = changeW($charm);
  88. }
  89. }
  90. }
  91. $seatdata = json_encode($seatdata);
  92. $matedata[$seatnum] = $seatdata;
  93. }
  94. //重新设置麦位小红心
  95. //获取房间用户周前三名 getPartyUserTop里面摘出来的一部分
  96. //[环信]更新财富榜前3。
  97. $avatarArr = $redis->hGet("user_jewel_top3",$party_info['id']);
  98. $matedata['wealth_top3_userlist'] = $avatarArr;
  99. $easemob->room_setRoomCustomAttributeForced($easemob_room_id,$party_info['user_id'],$matedata);
  100. return true;
  101. }
  102. }