SubscribeController.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Components\Helpers;
  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. * @package App\Http\Controllers\Controller
  15. */
  16. class SubscribeController extends Controller {
  17. protected static $systemConfig;
  18. function __construct() {
  19. self::$systemConfig = Helpers::systemConfig();
  20. }
  21. // 订阅码列表
  22. public function subscribeList(Request $request) {
  23. $user_id = $request->input('user_id');
  24. $email = $request->input('email');
  25. $status = $request->input('status');
  26. $query = UserSubscribe::with(['user:id,email']);
  27. if(isset($user_id)){
  28. $query->whereUserId($user_id);
  29. }
  30. if(isset($email)){
  31. $query->whereHas('user', function($q) use ($email) {
  32. $q->where('email', 'like', '%'.$email.'%');
  33. });
  34. }
  35. if(isset($status)){
  36. $query->whereStatus($status);
  37. }
  38. $view['subscribeList'] = $query->orderByDesc('id')->paginate(20)->appends($request->except('page'));
  39. return Response::view('admin.subscribe.subscribeList', $view);
  40. }
  41. //订阅记录
  42. public function subscribeLog(Request $request) {
  43. $id = $request->input('id');
  44. $query = UserSubscribeLog::with('user:email');
  45. if(isset($id)){
  46. $query->whereSid($id);
  47. }
  48. $view['subscribeLog'] = $query->orderByDesc('id')->paginate(20)->appends($request->except('page'));
  49. return Response::view('admin.subscribe.subscribeLog', $view);
  50. }
  51. // 设置用户的订阅的状态
  52. public function setSubscribeStatus(Request $request) {
  53. $id = $request->input('id');
  54. $status = $request->input('status', 0);
  55. if(empty($id)){
  56. return Response::json(['status' => 'fail', 'data' => '', 'message' => '操作异常']);
  57. }
  58. if($status){
  59. UserSubscribe::query()->whereId($id)->update(['status' => 1, 'ban_time' => 0, 'ban_desc' => '']);
  60. }else{
  61. UserSubscribe::query()->whereId($id)->update(['status' => 0, 'ban_time' => time(), 'ban_desc' => '后台手动封禁']);
  62. }
  63. return Response::json(['status' => 'success', 'data' => '', 'message' => '操作成功']);
  64. }
  65. }