UserService.php 8.8 KB

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