PromotionController.php 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  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. $linkSourceMap = [
  20. '0' => '',
  21. '1' => 'tiktok'
  22. ];
  23. $name = $request->input('name');
  24. $isConfig = $request->input('is_config', 1);
  25. $id = $request->input('id');
  26. $videoName = $request->input('video_name');
  27. $starTime = $request->input('start_time');
  28. $endTime = $request->input('end_time');
  29. $miniprogramId = $request->input('miniprogram_id');
  30. $result = DB::table('promotions')
  31. ->leftJoin('videos', 'videos.id', '=', 'promotions.video_id')
  32. ->leftJoin('miniprogram', 'miniprogram.id', '=', 'promotions.miniprogram_id')
  33. ->where(['promotions.is_enabled' => 1, 'promotions.uid' => $this->getLoginUserId()])
  34. ->when($miniprogramId, function ($query, $miniprogramId) {
  35. return $query->where('promotions.miniprogram_id', $miniprogramId);
  36. })
  37. ->when($isConfig, function ($query) {
  38. return $query->where('promotions.callback_config_id', '<>', 0);
  39. }, function ($query) {
  40. return $query->where('promotions.callback_config_id', 0);
  41. })->when($name, function ($query, $name){
  42. return $query->where('promotions.name', 'like', '%'. $name . '%');
  43. })->when($id, function ($query, $id) {
  44. return $query->where('promotions.id', $id);
  45. })->when($videoName, function ($query, $videoName) {
  46. return $query->where('videos.name', 'like', '%'. $videoName . '%');
  47. })->when($starTime, function ($query, $startTime) {
  48. return $query->where('promotions.created_at', '>=', $startTime);
  49. })->when($endTime, function ($query, $endTime){
  50. return $query->where('promotions.created_at', '<=', $endTime . ' 23:59:59');
  51. })->orderBy('created_at', 'desc')
  52. ->select('promotions.id', 'promotions.name', 'promotions.created_at',
  53. 'videos.name as video_name', 'promotions.series_sequence', 'promotions.callback_type',
  54. 'promotions.callback_config_id', 'promotions.video_id', 'promotions.remark', 'promotions.status', 'miniprogram.name as miniprogram_name')
  55. ->paginate($request->input('limit', 15));
  56. foreach ($result as $item) {
  57. $item->status_str = $item->status ? '启用':'禁用';
  58. $item->series_sequence_name = '第'. $item->series_sequence . '集';
  59. $item->callback_type_str = $callbackTypeMap[$item->callback_type] ?? '';
  60. $item->promotion_path = config('tuiguang.tuiguang.url') . DIRECTORY_SEPARATOR . 'api/promotion/index?ranse_id='. $item->id;
  61. $item->track_url = config('tuiguang.tuiguang.trackUrl') .
  62. '/track?dycallback=1&connection_id='.$item->id.
  63. '&link_source=' .( $linkSourceMap[$item->callback_type] ?? '') .
  64. '&adid=__AID__&cid=__CID__&imei=__IMEI__&oaid=__OAID__&mac=__MAC__&os=__OS__&ip=__IP__&androidid=__ANDROIDID__&ua=__UA__&timestamp=__TS__&callback_url=__CALLBACK_URL__&projectid=__PROJECT_ID__&promotionid=__PROMOTION_ID__&advertiser_id=__ADVERTISER_ID__&campaign_id=__CAMPAIGN_ID__';
  65. }
  66. return $result;
  67. }
  68. public function delete(Request $request) {
  69. $this->validate($request, ['id' => 'required']);
  70. DB::table('promotions')
  71. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  72. ->update(['is_enabled' => 0, 'updated_at' => date('Y-m-d H:i:s')]);
  73. return 'ok';
  74. }
  75. public function updateSeriesSequence(Request $request) {
  76. $this->validate($request, ['id' => 'required',
  77. 'series_sequence' => 'required', 'remark' => 'nullable|string|max:140']);
  78. DB::table('promotions')
  79. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  80. ->update(['series_sequence' => $request->input('series_sequence'),
  81. 'remark' => $request->input('remark', ''),
  82. 'updated_at' => date('Y-m-d H:i:s')]);
  83. return 'ok';
  84. }
  85. public function add(Request $request) {
  86. $this->validate($request, [
  87. 'video_id' => 'required',
  88. 'series_sequence' => 'required',
  89. 'name' => 'required',
  90. 'miniprogram_id' => 'required',
  91. ]);
  92. $now = date('Y-m-d H:i:s');
  93. DB::table('promotions')
  94. ->insert([
  95. 'uid' => $this->getLoginUserId(),
  96. 'miniprogram_id' => $request->input('miniprogram_id'),
  97. 'name' => $request->input('name'),
  98. 'video_id' => $request->input('video_id'),
  99. 'series_sequence' => $request->input('series_sequence'),
  100. 'created_at' => $now,
  101. 'updated_at' => $now,
  102. ]);
  103. return 'ok';
  104. }
  105. /**
  106. * 更新推广的回传配置
  107. * 1, 如果是巨量账户级,推广id和巨量账户唯一绑定
  108. * @param Request $request
  109. * @return string
  110. * @throws \Illuminate\Validation\ValidationException
  111. */
  112. public function updateCallbackConfig(Request $request) {
  113. $this->validate($request, [
  114. 'id' => 'required',
  115. 'callback_type' => 'required|in:1',
  116. 'callback_config_id' => 'required',
  117. 'remark' => 'nullable|string|max:140',
  118. ]);
  119. if(1 == $request->input('callback_type')) {
  120. $exist = DB::table('promotions')
  121. ->where(['is_enabled' => 1, 'callback_type' => $request->input('callback_type'),
  122. 'callback_config_id' => $request->input('callback_config_id'),
  123. 'status' => 1])
  124. ->first();
  125. if($exist && $exist->id != $request->input('id')) {
  126. CommonBusinessException::throwError(Errors::JULIANG_ACCOUNT_PROMOTION_UNIQUE);
  127. }
  128. }
  129. DB::table('promotions')
  130. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  131. ->update([
  132. 'callback_type' => $request->input('callback_type'),
  133. 'callback_config_id' => $request->input('callback_config_id'),
  134. 'remark' => $request->input('remark', ''),
  135. 'updated_at' => date('Y-m-d')
  136. ]);
  137. return 'ok';
  138. }
  139. }