SubscribeController.php 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\UserSubscribe;
  5. use App\Models\UserSubscribeLog;
  6. use Illuminate\Http\JsonResponse;
  7. use Illuminate\Http\Request;
  8. use Response;
  9. /**
  10. * 订阅控制器
  11. *
  12. * Class SubscribeController
  13. *
  14. * @package App\Http\Controllers\Controller
  15. */
  16. class SubscribeController extends Controller
  17. {
  18. // 订阅码列表
  19. public function subscribeList(Request $request)
  20. {
  21. $user_id = $request->input('user_id');
  22. $email = $request->input('email');
  23. $status = $request->input('status');
  24. $query = UserSubscribe::with(['user:id,email']);
  25. if (isset($user_id)) {
  26. $query->whereUserId($user_id);
  27. }
  28. if (isset($email)) {
  29. $query->whereHas(
  30. 'user',
  31. static function ($q) use ($email) {
  32. $q->where('email', 'like', '%' . $email . '%');
  33. }
  34. );
  35. }
  36. if (isset($status)) {
  37. $query->whereStatus($status);
  38. }
  39. $view['subscribeList'] = $query->latest()->paginate(20)->appends(
  40. $request->except('page')
  41. );
  42. return view('admin.subscribe.subscribeList', $view);
  43. }
  44. //订阅记录
  45. public function subscribeLog(Request $request)
  46. {
  47. $id = $request->input('id');
  48. $query = UserSubscribeLog::with('user:email');
  49. if (isset($id)) {
  50. $query->whereUserSubscribeId($id);
  51. }
  52. $view['subscribeLog'] = $query->latest()->paginate(20)->appends(
  53. $request->except('page')
  54. );
  55. return view('admin.subscribe.subscribeLog', $view);
  56. }
  57. // 设置用户的订阅的状态
  58. public function setSubscribeStatus(Request $request): JsonResponse
  59. {
  60. $id = $request->input('id');
  61. $status = $request->input('status', 0);
  62. if (empty($id)) {
  63. return Response::json(['status' => 'fail', 'message' => '操作异常']);
  64. }
  65. if ($status) {
  66. UserSubscribe::find($id)->update(
  67. ['status' => 1, 'ban_time' => null, 'ban_desc' => '']
  68. );
  69. } else {
  70. UserSubscribe::find($id)->update(
  71. ['status' => 0, 'ban_time' => time(), 'ban_desc' => '后台手动封禁']
  72. );
  73. }
  74. return Response::json(['status' => 'success', 'message' => '操作成功']);
  75. }
  76. }