UserService.php 6.5 KB

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