RoomService.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. <?php
  2. namespace app\common\service;
  3. use think\Db;
  4. use think\Exception;
  5. use Redis;
  6. class RoomService
  7. {
  8. private $model = '';
  9. private $redis = '';
  10. private $roomTypeArr = [];
  11. /**
  12. * 初始化方法
  13. */
  14. public function __construct()
  15. {
  16. $this->model = new \app\common\model\Party();
  17. $redis = new Redis();
  18. $redisconfig = config("redis");
  19. $redis->connect($redisconfig["host"], $redisconfig["port"]);
  20. if ($redisconfig['redis_pwd']) {
  21. $redis->auth($redisconfig['redis_pwd']);
  22. }
  23. if($redisconfig['redis_selectdb'] > 0){
  24. $redis->select($redisconfig['redis_selectdb']);
  25. }
  26. $this->redis = $redis;
  27. $this->roomTypeArr = [1=>"party",2=>"live"];
  28. }
  29. /**
  30. * 房间设置缓存
  31. * @return void
  32. */
  33. public function roomRedis($params=[])
  34. {
  35. $result = [
  36. 'status' => 1,
  37. 'msg' => '',
  38. 'data' => [],
  39. ];
  40. try {
  41. $room_type = isset($params['room_type']) ? $params['room_type'] : 0;
  42. if (!empty($room_type)) {
  43. //$userModel = new \app\common\model\User();
  44. // 直接从数据库获取所有数据
  45. $where = [];
  46. $where["a.status"] = 1;
  47. // $where["a.is_online"] = 1;
  48. $where["a.room_type"] = $room_type;
  49. $sqlPartyList = $this->model->alias("a")->field("a.*,b.name as type_name")
  50. ->join("hx_party_type b","a.party_type = b.id","left")->where($where)->select();
  51. /*$userList = $userModel->field("id,nickname,avatar")->where(["status"=>1])->select();
  52. $userInfoArr = [];
  53. if($userList) foreach($userList as $k => $v) $userInfoArr[$v["id"]] = $v;*/
  54. if($sqlPartyList) {
  55. foreach($sqlPartyList as $k => $v) {
  56. // 加入缓存排序
  57. //rediskey:派对热度
  58. $this->redis->zAdd($this->roomTypeArr[$room_type]."Rank", $v['party_hot'], $v["id"]);
  59. // 设置冠名
  60. //$sqlPartyList[$k]["naming"] = isset($userInfoArr[$v["naming"]])?$userInfoArr[$v["naming"]]:[];
  61. // 设置房主头像
  62. //$sqlPartyList[$k]["avatar"] = isset($userInfoArr[$v["user_id"]])?$userInfoArr[$v["user_id"]]["avatar"]:[];
  63. // 加入缓存
  64. //rediskey:派对详情
  65. $this->redis->set($this->roomTypeArr[$room_type]."_".$v["id"],json_encode($v));
  66. }
  67. //rediskey:派对热度
  68. $redisPartyRankList = $this->redis->zRevRange($this->roomTypeArr[$room_type]."Rank",0,-1,true);
  69. $result['data'] = $redisPartyRankList;
  70. }
  71. }
  72. } catch (Exception $e) {
  73. $result['status'] = 0;
  74. $result['msg'] = $e->getMessage();
  75. }
  76. return $result;
  77. }
  78. /**
  79. * 获取房间信息。没有地方使用
  80. */
  81. public function getRoomList($params=[])
  82. {
  83. $result = [
  84. 'status' => 1,
  85. 'msg' => '',
  86. 'data' => [],
  87. ];
  88. try {
  89. $partyIds = isset($params['ids']) ? $params['ids'] : [];
  90. $typeId = isset($params['type_id']) ? $params['type_id'] : 0;
  91. $isRecommend = isset($params['is_recommend']) ? $params['is_recommend'] : 0;
  92. $all = isset($params['is_recommend']) ? $params['all'] : 0;
  93. $start = isset($params['start']) ? $params['start'] : 1;
  94. $end = isset($params['end']) ? $params['end'] : 1;
  95. $index = isset($params['index']) ? $params['index'] : 0;
  96. if(!$partyIds) throw new Exception('未获取到房间ID');;
  97. $redisPartyInfo = $resdata = [];
  98. $where['status'] = 1;
  99. //$where['is_online'] = 1;
  100. $where['is_close'] = 0;
  101. $where['id'] = ['in',$partyIds];
  102. $field = 'id,room_type,party_hot';
  103. $partyData = $this->model->field($field)->where($where)->order('party_hot desc')->select();
  104. if (!empty($partyData)) {
  105. //获取房间用户信息
  106. /*$tenimService = new TenimService();
  107. $userParams = ['party_ids' => $partyIds];
  108. $userImRes = $tenimService->getRoomUser($userParams);*/
  109. foreach($partyData as $k => $v) {
  110. $roomType = $v['room_type'];
  111. $roomTypeStr = isset($this->roomTypeArr[$roomType]) ? $this->roomTypeArr[$roomType] : '';
  112. $getredisPartyInfo = $this->redis->get($roomTypeStr.'_'.$v['id']);
  113. $foreachData = json_decode($getredisPartyInfo,true);
  114. $isClose = isset($foreachData["is_close"]) ? $foreachData["is_close"] : 0;
  115. $partyPass = isset($foreachData["party_pass"]) ? $foreachData["party_pass"] : '';
  116. if(!$foreachData || $isClose == 1) continue;
  117. if(!$foreachData || $foreachData["is_online"] == 0) continue;
  118. //if(!$foreachData || $partyPass != '') continue;//设置密码的也显示
  119. $mod = isset($foreachData["party_type"])?intval($foreachData["party_type"])%5:1;
  120. if(isset($foreachData["type_name"]) && $foreachData["type_name"]) {
  121. $type_name = $foreachData["type_name"];
  122. } else {
  123. $type_name = "普通房";
  124. }
  125. $hasdata = false;
  126. if($all == 1) {
  127. if($isRecommend == 1) {
  128. if($foreachData["is_recommend"] == 1) $hasdata = true;
  129. } else {
  130. $hasdata = true;
  131. }
  132. } elseif($typeId > 0) {
  133. if($typeId == $foreachData["party_type"]) $hasdata = true;
  134. }
  135. if($foreachData["status"] != 1) $hasdata = false;
  136. $foreachData = info_domain_image($foreachData,['party_logo']);
  137. //$userIds = $this->redis->zRange("party_user_".$foreachData["id"],0,-1);
  138. if ($hasdata) {
  139. /*$field = 'user_id,avatar';
  140. $fieldArr = explode(',',$field);*/
  141. /*$userWhere['id'] = ['in', $userIds];
  142. $userModel = new \app\common\model\User();
  143. $userData = $userModel->field($field)->where($userWhere)->select();*/
  144. $userDataResult = $this->getPartyUserList(['party_id'=>$v['id']]);
  145. $userDataRes = isset($userDataResult['data']) ? $userDataResult['data'] : [];
  146. $userData = isset($userDataRes['member_list']) ? $userDataRes['member_list'] : [];
  147. $userDatas = [];
  148. if (!empty($userData)) {
  149. $userDatas = $userData;
  150. $userDatas = list_domain_image($userDatas,['avatar']);
  151. }
  152. $partyUserList = [
  153. 'user_list' => $userDatas,
  154. 'online_num' => count($userData),
  155. ];
  156. $redisPartyInfo[] = [
  157. "id" => $foreachData["id"],
  158. "room_type" => $v['room_type'],
  159. "party_id" => $foreachData["party_id"],
  160. "r_id" => $foreachData["party_id"],
  161. "party_name" => $foreachData["party_name"],
  162. "party_pass" => $foreachData["party_pass"] ? $foreachData["party_pass"]:"",
  163. "party_hot" => $v['party_hot'],
  164. "party_logo" => $foreachData["party_logo"],
  165. "party_type" => $type_name,
  166. "avatar" => $roomType == 2 ? $foreachData["avatar"]:"",
  167. "party_type_color" => $mod == 0?5:$mod,
  168. "party_user" => $partyUserList,
  169. ];
  170. }
  171. }
  172. if($index == 1) {
  173. $num = $end - $start + 1;
  174. $countData = count($redisPartyInfo);
  175. if($num > $countData) $num = $countData;
  176. if($redisPartyInfo) {
  177. $dataRand = array_rand($redisPartyInfo,$num);
  178. $dataRand = is_array($dataRand)?$dataRand:[$dataRand];
  179. if($redisPartyInfo) {
  180. foreach($redisPartyInfo as $k => $v) {
  181. if(in_array($k,$dataRand)) $resdata[] = $v;
  182. }
  183. }
  184. }
  185. } else {
  186. if($redisPartyInfo) {
  187. foreach($redisPartyInfo as $k => $v){
  188. if($k >= $start && $k <= $end) $resdata[] = $v;
  189. }
  190. }
  191. }
  192. }
  193. $result['data'] = $resdata;
  194. } catch (Exception $e) {
  195. $result['status'] = 0;
  196. $result['msg'] = $e->getMessage();
  197. }
  198. return $result;
  199. }
  200. /**
  201. * 房间用户信息
  202. * @return void
  203. */
  204. public function getPartyUserList($params=[])
  205. {
  206. $result = [
  207. 'status' => 1,
  208. 'msg' => '',
  209. 'data' => [],
  210. ];
  211. try {
  212. $partyId = isset($params['party_id']) ? $params['party_id'] : 0;
  213. //rediskey:派对用户列表
  214. // $userIds = $this->redis->zRange("party_user_".$partyId,0,-1);
  215. $userIds = $this->redis->hGetAll("online_" . $partyId);
  216. $field = 'id,avatar,nickname';
  217. $userWhere['id'] = ['in', $userIds];
  218. // $userWhere['is_stealth'] = 0;
  219. $userModel = new \app\common\model\User();
  220. $userData = $userModel->field($field)->where($userWhere)->limit(20)->select();
  221. $userDatas = [];
  222. if (!empty($userData)) {
  223. foreach($userData as $key => $value) {
  224. $userDatas[$key] = $value;
  225. }
  226. $userDatas = list_domain_image($userDatas,['avatar']);
  227. }
  228. $partyUserList = [
  229. 'member_list' => $userDatas,
  230. 'online_num' => count($userIds),
  231. ];
  232. $result['data'] = $partyUserList;
  233. } catch (Exception $e) {
  234. $result['status'] = 0;
  235. $result['msg'] = $e->getMessage();
  236. }
  237. return $result;
  238. }
  239. }