PromotionController.php 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  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. /**
  15. * 推广列表
  16. * @param Request $request
  17. * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator
  18. */
  19. public function list(Request $request) {
  20. $callbackTypeMap = [
  21. '0' => '无',
  22. '1' => '头条-微信(账户级)',
  23. '2' => '巨量2.0事件-微信小程序',
  24. ];
  25. $linkSourceMap = [
  26. '0' => '',
  27. '1' => 'tiktok'
  28. ];
  29. $name = $request->input('name');
  30. $isConfig = $request->input('is_config', 0);
  31. $id = $request->input('id');
  32. $videoName = $request->input('video_name');
  33. $starTime = $request->input('start_time');
  34. $endTime = $request->input('end_time');
  35. $miniprogramId = $request->input('miniprogram_id');
  36. $result = DB::table('promotions')
  37. ->leftJoin('videos', 'videos.id', '=', 'promotions.video_id')
  38. ->where(['promotions.is_enabled' => 1, 'promotions.uid' => $this->getLoginUserId()])
  39. ->when($miniprogramId, function ($query, $miniprogramId) {
  40. return $query->where('promotions.miniprogram_id', $miniprogramId);
  41. })
  42. ->when($isConfig, function ($query) {
  43. return $query->where('promotions.callback_config_id', '<>', 0);
  44. }, function ($query) {
  45. return $query->where('promotions.callback_config_id', 0);
  46. })->when($name, function ($query, $name){
  47. return $query->where('promotions.name', 'like', '%'. $name . '%');
  48. })->when($id, function ($query, $id) {
  49. return $query->where('promotions.id', $id);
  50. })->when($videoName, function ($query, $videoName) {
  51. return $query->where('videos.name', 'like', '%'. $videoName . '%');
  52. })->when($starTime, function ($query, $startTime) {
  53. return $query->where('promotions.created_at', '>=', $startTime);
  54. })->when($endTime, function ($query, $endTime){
  55. return $query->where('promotions.created_at', '<=', $endTime . ' 23:59:59');
  56. })->orderBy('created_at', 'desc')
  57. ->select('promotions.*', 'videos.name as video_name')
  58. ->paginate($request->input('limit', 15));
  59. $chargeTemplateIds = $result->pluck('first_charge_template_id')->merge($result->pluck('not_first_charge_template_id'))->unique();
  60. $payTemplates = DB::table('pay_templates')->whereIn('id', $chargeTemplateIds)
  61. ->select('id', 'name')
  62. ->get()->keyBy('id')->toArray();
  63. $yinliuGzhids = $result->pluck('yinliu_gzhid')->diff([0]);
  64. $gzhs = $yinliuGzhids->isEmpty() ? collect() :
  65. DB::table('wechat_authorization_infos')
  66. ->whereIn('id', $yinliuGzhids)
  67. ->select('id', 'nick_name')->get()->keyBy('id');
  68. foreach ($result as $item) {
  69. $item->status_str = $item->status ? '启用':'禁用';
  70. $item->series_sequence_name = '第'. $item->series_sequence . '集';
  71. $item->callback_type_str = $callbackTypeMap[$item->callback_type] ?? '';
  72. $item->promotion_path = config('tuiguang.tuiguang.url') . DIRECTORY_SEPARATOR . 'api/promotion/index?ranse_id='. $item->id;
  73. $item->track_url = config('tuiguang.tuiguang.trackUrl') .
  74. '/track?dycallback=1&connection_id='.$item->id.
  75. '&link_source=' .( $linkSourceMap[$item->callback_type] ?? '') .
  76. '&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__';
  77. $item->first_charge_template_str = $payTemplates[$item->first_charge_template_id]->name ?? '';
  78. $item->not_first_charge_template_str = $payTemplates[$item->not_first_charge_template_id]->name ?? '';
  79. $item->yinliu_type_str = 1 == $item->yinliu_type ? '公众号引流' : '';
  80. $item->yinliu_gzhid_str = $gzhs->get($item->yinliu_gzhid)->nick_name ?? '';
  81. }
  82. return $result;
  83. }
  84. public function delete(Request $request) {
  85. $this->validate($request, ['id' => 'required']);
  86. DB::table('promotions')
  87. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  88. ->update(['is_enabled' => 0, 'updated_at' => date('Y-m-d H:i:s')]);
  89. return 'ok';
  90. }
  91. public function updateSeriesSequence(Request $request) {
  92. $this->validate($request, ['id' => 'required',
  93. 'series_sequence' => 'required', 'remark' => 'nullable|string|max:140',
  94. 'first_charge_template_id' => 'required',
  95. 'not_first_charge_template_id' => 'required',
  96. 'yinliu_enabled' => 'required|in:0,1',
  97. 'yinliu_type' => 'required_if:yinliu_enabled,1|in:1',
  98. 'yinliu_gzhid' => 'required_if:yinliu_enabled,1',
  99. 'yinliu_sequence' => 'required_if:yinliu_enabled,1|min:1'
  100. ]);
  101. DB::table('promotions')
  102. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  103. ->update(['series_sequence' => $request->input('series_sequence'),
  104. 'remark' => $request->input('remark') ?? '',
  105. 'first_charge_template_id' => $request->input('first_charge_template_id'),
  106. 'not_first_charge_template_id' => $request->input('not_first_charge_template_id'),
  107. 'yinliu_enabled' => $request->input('yinliu_enabled'),
  108. 'yinliu_type' => $request->input('yinliu_type',1),
  109. 'yinliu_gzhid' => $request->input('yinliu_gzhid', 0),
  110. 'yinliu_sequence' => $request->input('yinliu_sequence', 0),
  111. 'updated_at' => date('Y-m-d H:i:s')]);
  112. return 'ok';
  113. }
  114. public function add(Request $request) {
  115. $this->validate($request, [
  116. 'video_id' => 'required',
  117. 'series_sequence' => 'required',
  118. 'name' => 'required',
  119. 'miniprogram_id' => 'required',
  120. 'first_charge_template_id' => 'required',
  121. 'not_first_charge_template_id' => 'required',
  122. ]);
  123. $now = date('Y-m-d H:i:s');
  124. $currentUser = $this->getCurrentUser();
  125. DB::table('promotions')
  126. ->insert([
  127. 'uid' => $currentUser->id,
  128. 'puid' => $currentUser->pid,
  129. 'miniprogram_id' => $request->input('miniprogram_id'),
  130. 'name' => $request->input('name'),
  131. 'video_id' => $request->input('video_id'),
  132. 'series_sequence' => $request->input('series_sequence'),
  133. 'first_charge_template_id' => $request->input('first_charge_template_id'),
  134. 'not_first_charge_template_id' => $request->input('not_first_charge_template_id'),
  135. 'created_at' => $now,
  136. 'updated_at' => $now,
  137. ]);
  138. return 'ok';
  139. }
  140. /**
  141. * 更新推广的回传配置
  142. * 1, 如果是巨量账户级,推广id和巨量账户唯一绑定
  143. * @param Request $request
  144. * @return string
  145. * @throws \Illuminate\Validation\ValidationException
  146. */
  147. public function updateCallbackConfig(Request $request) {
  148. $this->validate($request, [
  149. 'id' => 'required',
  150. 'callback_type' => 'required|in:1,2',
  151. 'callback_config_id' => 'required',
  152. 'remark' => 'nullable|string|max:140',
  153. ]);
  154. if(1 == $request->input('callback_type')) {
  155. $exist = DB::table('promotions')
  156. ->where(['is_enabled' => 1, 'callback_type' => $request->input('callback_type'),
  157. 'callback_config_id' => $request->input('callback_config_id'),
  158. 'status' => 1])
  159. ->first();
  160. if($exist && $exist->id != $request->input('id')) {
  161. CommonBusinessException::throwError(Errors::JULIANG_ACCOUNT_PROMOTION_UNIQUE);
  162. }
  163. }
  164. DB::table('promotions')
  165. ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])
  166. ->update([
  167. 'callback_type' => $request->input('callback_type'),
  168. 'callback_config_id' => $request->input('callback_config_id'),
  169. 'remark' => $request->input('remark', ''),
  170. 'updated_at' => date('Y-m-d')
  171. ]);
  172. return 'ok';
  173. }
  174. }