UserService.php 11 KB

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