SubscribeController.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Components\IP;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\UserSubscribe;
  6. use App\Models\UserSubscribeLog;
  7. use Illuminate\Http\Request;
  8. use Response;
  9. /**
  10. * 订阅控制器.
  11. *
  12. * Class SubscribeController
  13. */
  14. class SubscribeController extends Controller
  15. {
  16. // 订阅码列表
  17. public function index(Request $request)
  18. {
  19. $query = UserSubscribe::with(['user:id,username']);
  20. $request->whenFilled('username', function ($username) use ($query) {
  21. $query->whereHas('user', function ($query) use ($username) {
  22. $query->where('username', 'like', "%{$username}%");
  23. });
  24. });
  25. foreach (['user_id', 'status', 'code'] as $field) {
  26. $request->whenFilled($field, function ($value) use ($query, $field) {
  27. $query->where($field, $value);
  28. });
  29. }
  30. return view('admin.subscribe.index', ['subscribeList' => $query->sortable(['id' => 'desc'])->paginate(20)->appends($request->except('page'))]);
  31. }
  32. //订阅记录
  33. public function subscribeLog(Request $request, $userSubscribeId)
  34. {
  35. $query = UserSubscribeLog::whereUserSubscribeId($userSubscribeId);
  36. $request->whenFilled('id', function ($value) use ($query) {
  37. $query->where('id', $value);
  38. });
  39. $request->whenFilled('ip', function ($value) use ($query) {
  40. $query->where('request_ip', 'like', "%{$value}%");
  41. });
  42. if ($request->filled('start')) {
  43. $query->whereBetween('request_time', [$request->input('start').' 00:00:00', $request->input('end').' 23:59:59']);
  44. }
  45. $subscribeLogs = $query->latest()->paginate(20)->appends($request->except('page'));
  46. foreach ($subscribeLogs as $log) {
  47. // 跳过上报多IP的
  48. if ($log->request_ip) {
  49. $log->ipInfo = implode(' ', IP::getIPInfo($log->request_ip));
  50. }
  51. }
  52. return view('admin.subscribe.log', ['subscribeLog' => $subscribeLogs, 'subscribe' => UserSubscribe::find($userSubscribeId)]);
  53. }
  54. // 设置用户的订阅的状态
  55. public function setSubscribeStatus(UserSubscribe $subscribe)
  56. {
  57. if ($subscribe->status) {
  58. $subscribe->update(['status' => 0, 'ban_time' => time(), 'ban_desc' => '后台手动封禁']);
  59. } else {
  60. $subscribe->update(['status' => 1, 'ban_time' => null, 'ban_desc' => '']);
  61. }
  62. return Response::json(['status' => 'success', 'message' => '操作成功']);
  63. }
  64. }