WechatCheckController.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  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. use Modules\Manage\Services\WechatMiniprogramService;
  9. /**
  10. * 微信提审
  11. */
  12. class WechatCheckController extends CatchController
  13. {
  14. use ValidatesRequests;
  15. /**
  16. * 添加提审
  17. * @param Request $request
  18. */
  19. public function add(Request $request) {
  20. $this->validate($request, [
  21. 'video_id'=>'required',
  22. 'producer' => 'required|string|max:256',
  23. 'playwright' => 'required|string|max:256',
  24. 'production_license_img' => 'required|url',
  25. 'authorized_img' => 'required|url',
  26. 'registration_number' => 'required'
  27. ]);
  28. $data = $request->all();
  29. $appid = WechatMiniprogramService::getDuanjuCheckAppid();
  30. $data['created_at'] = $data['updated_at'] = date('Y-m-d H:i:s');
  31. $data['appid'] = $appid;
  32. DB::table('video_wechat_check')
  33. ->insert($data);
  34. return 'ok';
  35. }
  36. /**
  37. * 修改
  38. * @param Request $request
  39. */
  40. public function update(Request $request) {
  41. $this->validate($request, [
  42. 'id'=>'required',
  43. 'producer' => 'required|string|max:256',
  44. 'playwright' => 'required|string|max:256',
  45. 'production_license_img' => 'required|url',
  46. 'authorized_img' => 'required|url',
  47. 'registration_number' => 'required'
  48. ]);
  49. $data = $request->only(['producer', 'playwright', 'production_license_img', 'authorized_img', 'registration_number']);
  50. $data['updated_at'] = date('Y-m-d H:i:s');
  51. DB::table('video_wechat_check')
  52. ->where('id', $request->input('id'))
  53. ->where('is_enabled', 1)
  54. ->whereIn('status', [0,4])
  55. ->update($data);
  56. return 'ok';
  57. }
  58. /**
  59. * 删除
  60. * @param Request $request
  61. */
  62. public function delete(Request $request) {
  63. $this->validate($request, ['id' => 'required']);
  64. DB::table('video_wechat_check')
  65. ->whereIn('status', [0,4])
  66. ->where([
  67. 'id' => $request->input('id'),
  68. 'is_enabled' => 1,
  69. ])->update([
  70. 'is_enabled' => 0,
  71. 'updated_at' => date('Y-m-d H:i:s')
  72. ]);
  73. return 'ok';
  74. }
  75. /**
  76. * 提审记录列表
  77. * @param Request $request
  78. */
  79. public function list(Request $request) {
  80. $videoId = $request->input('video_id');
  81. $producer = $request->input('producer');
  82. $playwright = $request->input('playwright');
  83. $status = $request->input('status','0');
  84. $result = DB::table('video_wechat_check as check')
  85. ->join('videos', 'videos.id', 'check.video_id')
  86. ->whereIn('check.status', explode(',', $status))
  87. ->where([
  88. 'check.is_enabled' => 1,
  89. ])->when($videoId, function ($query, $videoId) {
  90. return $query->where('check.video_id', $videoId);
  91. })->when($producer, function ($query, $producer){
  92. return $query->where('check.producer', 'like', '%'. $producer. '%');
  93. })->when($playwright, function ($query, $playwright){
  94. return $query->where('check.playwright', 'like', '%'. $playwright. '%');
  95. })->select('check.id', 'videos.name', 'videos.note', 'videos.total_episode_num',
  96. 'videos.cover_image','check.status','check.producer',
  97. 'check.playwright', 'check.production_license_img', 'check.authorized_img', 'check.apply_at',
  98. 'check.check_at', 'check.check_reason', 'check.registration_number', 'check.video_id')
  99. ->orderBy('check.id','desc')
  100. ->paginate($request->input('limit', 20));
  101. $statusMap = config('video.wechat.dramaCheckStatus');
  102. foreach ($result as $item) {
  103. $item->status_str = $statusMap[$item->status] ?? '';
  104. }
  105. return $result;
  106. }
  107. /**
  108. * 微信提审
  109. * @param Request $request
  110. */
  111. public function check(Request $request) {
  112. $this->validate($request, [
  113. 'ids' => 'required|array'
  114. ]);
  115. $ids = $request->input('ids');
  116. $now = date('Y-m-d H:i:s');
  117. DB::table('video_wechat_check')
  118. ->whereIn('id', $ids)
  119. ->whereIn('status', [0, 4])
  120. ->update([
  121. 'status' => 5,
  122. 'updated_at' => $now,
  123. 'apply_at' => $now,
  124. ]);
  125. $traceContext = getTraceContext();
  126. foreach ($ids as $id) {
  127. WechatCheck::dispatch([
  128. 'id' => $id,
  129. 'traceInfo' => $traceContext->getTraceInfo()
  130. ])->onQueue('{duanju_manage}.video.wechatCheck')->onConnection('queue-redis');
  131. }
  132. return 'ok';
  133. }
  134. }