WechatCheckController.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. namespace Modules\Video\Http\Controllers;
  3. use App\Jobs\Video\WechatCheck;
  4. use Catch\Base\CatchController;
  5. use Illuminate\Foundation\Validation\ValidatesRequests;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\DB;
  8. /**
  9. * 微信提审
  10. */
  11. class WechatCheckController extends CatchController
  12. {
  13. use ValidatesRequests;
  14. /**
  15. * 添加提审
  16. * @param Request $request
  17. */
  18. public function add(Request $request) {
  19. $this->validate($request, [
  20. 'video_id'=>'required',
  21. 'producer' => 'required|string|max:256',
  22. 'playwright' => 'required|string|max:256',
  23. 'production_license_img' => 'required|url',
  24. 'authorized_img' => 'required|url'
  25. ]);
  26. $data = $request->all();
  27. $data['created_at'] = $data['updated_at'] = date('Y-m-d H:i:s');
  28. DB::table('video_wechat_check')
  29. ->insert($data);
  30. return 'ok';
  31. }
  32. /**
  33. * 修改
  34. * @param Request $request
  35. */
  36. public function update(Request $request) {}
  37. /**
  38. * 删除
  39. * @param Request $request
  40. */
  41. public function delete(Request $request) {
  42. $this->validate($request, ['id' => 'required']);
  43. DB::table('video_wechat_check')
  44. ->where([
  45. 'id' => $request->input('id'),
  46. 'is_enabled' => 1,
  47. ])->update([
  48. 'is_enabled' => 0,
  49. 'updated_at' => date('Y-m-d H:i:s')
  50. ]);
  51. return 'ok';
  52. }
  53. /**
  54. * 提审记录列表
  55. * @param Request $request
  56. */
  57. public function list(Request $request) {
  58. $videoId = $request->input('video_id');
  59. $producer = $request->input('producer');
  60. $playwright = $request->input('playwright');
  61. $status = $request->input('status',0);
  62. return DB::table('video_wechat_check as check')
  63. ->join('videos', 'videos.id', 'check.video_id')
  64. ->where([
  65. 'check.status' => $status,
  66. 'check.is_enabled' => 1,
  67. ])->when($videoId, function ($query, $videoId) {
  68. return $query->where('check.video_id', $videoId);
  69. })->when($producer, function ($query, $producer){
  70. return $query->where('check.producer', 'like', '%'. $producer. '%');
  71. })->when($playwright, function ($query, $playwright){
  72. return $query->where('check.playwright', 'like', '%'. $playwright. '%');
  73. })->select('check.id', 'videos.name', 'videos.note', 'videos.total_episode_num',
  74. 'videos.cover_image','check.status','check.producer',
  75. 'check.playwright', 'check.production_license_img', 'check.authorized_img', 'check.apply_at',
  76. 'check.check_at', 'check.check_reason')
  77. ->orderBy('check.id','desc')
  78. ->paginate($request->input('limit', 10));
  79. }
  80. /**
  81. * 微信提审
  82. * @param Request $request
  83. */
  84. public function wechatCheck(Request $request) {
  85. $this->validate($request, [
  86. 'ids' => 'required|array'
  87. ]);
  88. $ids = $request->input('ids');
  89. $now = date('Y-m-d H:i:s');
  90. DB::table('video_wechat_check')
  91. ->whereIn('id', $ids)
  92. ->whereIn('status', [0, 4])
  93. ->update([
  94. 'status' => 5,
  95. 'updated_at' => $now,
  96. 'apply_at' => $now,
  97. ]);
  98. $traceContext = getTraceContext();
  99. foreach ($ids as $id) {
  100. WechatCheck::dispatch([
  101. 'id' => $id,
  102. 'traceInfo' => $traceContext->getTraceInfo()
  103. ])->onQueue('{duanju_manage}.video.wechatCheck')->onConnection('queue-redis');
  104. }
  105. return 'ok';
  106. }
  107. }