SubscribeController.php 2.5 KB

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