PromotionController.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. <?php
  2. namespace Modules\Tuiguang\Http\Controllers;
  3. use Catch\Base\CatchController;
  4. use Illuminate\Foundation\Validation\ValidatesRequests;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. use Modules\Common\Errors\Errors;
  8. use Modules\Common\Exceptions\CommonBusinessException;
  9. use Modules\User\Http\Controllers\UserTrait;
  10. class PromotionController extends CatchController
  11. {
  12. use UserTrait;
  13. use ValidatesRequests;
  14. public function list(Request $request) {
  15. $callbackTypeMap = [
  16. '0' => '无',
  17. '1' => '巨量账户级回传',
  18. ];
  19. $name = $request->input('name');
  20. $isConfig = $request->input('is_config', 1);
  21. $id = $request->input('id');
  22. $videoName = $request->input('video_name');
  23. $starTime = $request->input('start_time');
  24. $endTime = $request->input('endTime');
  25. $miniprogramId = $request->input('miniprogram_id');
  26. $result = DB::table('promotions')
  27. ->leftJoin('videos', 'videos.id', '=', 'promotions.video_id')
  28. ->where(['promotions.is_enabled' => 1, 'promotions.uid' => $this->getLoginUserId()])
  29. ->when($miniprogramId, function ($query, $miniprogramId) {
  30. return $query->where('promotions.miniprogram_id', $miniprogramId);
  31. })
  32. ->when($isConfig, function ($query) {
  33. return $query->where('promotions.callback_config_id', '<>', 0);
  34. }, function ($query) {
  35. return $query->where('promotions.callback_config_id', 0);
  36. })->when($name, function ($query, $name){
  37. return $query->where('promotions.name', 'like', '%'. $name . '%');
  38. })->when($id, function ($query, $id) {
  39. return $query->where('promotions.id', $id);
  40. })->when($videoName, function ($query, $videoName) {
  41. return $query->where('videos.name', 'like', '%'. $videoName . '%');
  42. })->when($starTime, function ($query, $startTime) {
  43. return $query->where('promotions.created_at', '>=', $startTime);
  44. })->when($endTime, function ($query, $endTime){
  45. return $query->where('promotions.created_at', '<=', $endTime);
  46. })->select('promotions.id', 'promotions.name', 'promotions.created_at',
  47. 'videos.name as video_name', 'promotions.series_sequence', 'promotions.callback_type', 'promotions.callback_config_id')
  48. ->paginate($request->input('limit', 15));
  49. foreach ($result as $item) {
  50. $item->callback_type_str = $callbackTypeMap[$item->callback_type] ?? '';
  51. // todo: 待完善
  52. $item->promotion_path = '';
  53. $item->track_url = '';
  54. }
  55. return $result;
  56. }
  57. public function delete(Request $request) {
  58. $this->validate($request, ['id' => 'required']);
  59. DB::table('promotions')
  60. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  61. ->update(['is_enabled' => 0, 'updated_at' => date('Y-m-d H:i:s')]);
  62. return 'ok';
  63. }
  64. public function updateSeriesSequence(Request $request) {
  65. $this->validate($request, ['id' => 'required', 'series_sequence' => 'required']);
  66. DB::table('promotions')
  67. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  68. ->update(['series_sequence' => $request->input('series_sequence')
  69. , 'updated_at' => date('Y-m-d H:i:s')]);
  70. return 'ok';
  71. }
  72. public function add(Request $request) {
  73. $this->validate($request, [
  74. 'video_id' => 'required',
  75. 'series_sequence' => 'required',
  76. 'name' => 'required',
  77. 'miniprogram_id' => 'required',
  78. ]);
  79. $now = date('Y-m-d H:i:s');
  80. DB::table('promotions')
  81. ->insert([
  82. 'uid' => $this->getLoginUserId(),
  83. 'miniprogram_id' => $request->input('miniprogram_id'),
  84. 'name' => $request->input('name'),
  85. 'video_id' => $request->input('video_id'),
  86. 'series_sequence' => $request->input('series_sequence'),
  87. 'created_at' => $now,
  88. 'updated_at' => $now,
  89. ]);
  90. return 'ok';
  91. }
  92. public function updateCallbackConfig(Request $request) {
  93. $this->validate($request, [
  94. 'id' => 'required',
  95. 'callback_type' => 'required|in:1',
  96. 'callback_config_id' => 'required'
  97. ]);
  98. DB::table('promotions')
  99. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  100. ->update([
  101. 'callback_type' => $request->input('callback_type'),
  102. 'callback_config_id' => $request->input('callback_config_id'),
  103. 'updated_at' => date('Y-m-d')
  104. ]);
  105. return 'ok';
  106. }
  107. }