UserService.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <?php
  2. namespace App\Services;
  3. use App\Http\Params\ProblemParam;
  4. use App\Models\PaymentLogModel;
  5. use App\Models\User;
  6. use App\Models\UserBlacklistModel;
  7. use App\Models\UserInviteLog;
  8. use App\Models\UserLookModel;
  9. use App\Models\UserProblemModel;
  10. use App\Models\VipModel;
  11. use Illuminate\Support\Facades\DB;
  12. use PHPUnit\Util\Exception;
  13. use function Symfony\Component\Translation\t;
  14. class UserService
  15. {
  16. /**
  17. * 问题反馈
  18. */
  19. public function problem(ProblemParam $param){
  20. if(empty($param->content)){
  21. throw new Exception("请输入问题");
  22. }
  23. $ins = array();
  24. $ins['user_id'] = $param->user_id;
  25. $ins['content'] = htmlspecialchars($param->content);
  26. $ins['img_url'] = json_encode($param->img_url);
  27. $ins['status'] = $param->status;
  28. UserProblemModel::query()->create($ins);
  29. return true;
  30. }
  31. /**
  32. * 看过我
  33. */
  34. public function looked_me($param){
  35. $res = UserLookModel::query()
  36. ->with(['user'=>function($query){
  37. $query->select('id','sex','is_vip','tencent_im_user_id');
  38. },'user_info'])
  39. ->where('look_id',$param['user_id'])
  40. ->paginate(request('perPage',20));
  41. return $res;
  42. }
  43. /**
  44. * 购买vip
  45. */
  46. public function buy_vip($param){
  47. if(empty($param['id'])){
  48. throw new Exception("参数错误");
  49. }
  50. if(!$vip_info = VipModel::query()->where('id',$param['id'])->first()){
  51. throw new Exception("VIP不存在");
  52. }
  53. $ins = array();
  54. $ins['order_no'] = create_order_number();
  55. $ins['user_id'] = $param['user_id'];
  56. $ins['price'] = $vip_info['price'];
  57. $ins['status'] = 0;
  58. $ins['content'] = json_encode($vip_info);
  59. $ins['type'] = 1;
  60. $ins['payment'] = $param['payment'];
  61. if(!PaymentLogModel::query()->create($ins)){
  62. throw new Exception("插入订单失败");
  63. }
  64. $pay_param = [
  65. 'out_trade_no' => $ins['order_no'],
  66. 'body' => '购买VIP',
  67. 'total_fee' => $ins['price'],
  68. 'payment' => $ins['payment'],
  69. ];
  70. return PayService::pay($pay_param);
  71. }
  72. /**
  73. * 黑名单
  74. */
  75. public function black_list(){
  76. $user = auth('api')->user();
  77. $res = UserBlacklistModel::query()
  78. ->leftJoin('users_info','users_blacklist.black_id','=','users_info.user_id')
  79. ->select(['users_blacklist.id','users_info.user_id','users_info.avatar','users_info.nickname'])
  80. ->where('users_blacklist.user_id','=',$user->id)
  81. ->paginate(request('prePage',20));
  82. return $res;
  83. }
  84. /**
  85. * 移除黑名单
  86. */
  87. public function del_black($id){
  88. if(empty($id)){
  89. throw new Exception("参数错误");
  90. }
  91. $user = auth('api')->user();
  92. if(!$black = UserBlacklistModel::query()->where(['id'=>$id,'user_id'=>$user->id])->first()){
  93. throw new Exception("对方不在你的黑名单中");
  94. }
  95. $black->delete();
  96. return true;
  97. }
  98. /**
  99. * 设置隐身和通知开关
  100. */
  101. public function online_status($request){
  102. $user = auth('api')->user();
  103. if(isset($request->online)){
  104. $user->online = $request->online;
  105. $user->save();
  106. }
  107. if(isset($request->notice_status)){
  108. $user->notice_status = $request->notice_status;
  109. $user->save();
  110. }
  111. return ['online'=>$user->online,'notice_status'=>$user->notice_status];
  112. }
  113. /**
  114. * 获取邀请福利信息
  115. */
  116. public function invite_info(){
  117. $user = auth('api')->user();
  118. $res['ycode'] = $user->ycode;
  119. $res['code_url'] = "https://".$_SERVER['HTTP_HOST'].'/h5/reg.html?invoce='.$user->ycode;
  120. //总邀请用户
  121. $res['total_user'] =User::query()->where(['pid'=>$user->id])->count();
  122. //待领取天数
  123. $res['unclaimed'] = UserInviteLog::query()->where(['user_id'=>$user->id,'status'=>0])->sum('day');
  124. //累计领取天数
  125. $res['total_day'] = UserInviteLog::query()->where(['user_id'=>$user->id,'status'=>1])->sum('day');
  126. //奖励规则
  127. $res['rule'] = DB::table("document")->where(['id'=>4])->value('content');
  128. return $res;
  129. }
  130. /**
  131. * 获取邀请用户列表
  132. * @param $requset
  133. */
  134. public function get_invite_list(){
  135. $user = auth('api')->user();
  136. $list = User::query()
  137. ->where(['users.pid'=>$user->id])
  138. ->leftJoin('users_info','users.id','=','users_info.user_id')
  139. ->select(['users.id','users.created_at','users.is_vip','users_info.nickname'])
  140. ->orderBy('id','desc')
  141. ->paginate(request('prePage',10));
  142. $list = $list->toArray();
  143. foreach ($list['data'] as $k=>$v){
  144. $list['data'][$k]['created_at'] = date('Y/m/d',strtotime($v['created_at']));
  145. }
  146. return $list;
  147. }
  148. }