UserService.php 9.8 KB

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