JLEventController.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <?php
  2. namespace Modules\Callback\Http\Controllers\JLEvent;
  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\Callback\Models\JLEventCallbackConfigModel;
  8. use Modules\Callback\Services\CallbackConst;
  9. use Modules\Callback\Services\JLEventService;
  10. use Modules\Common\Errors\Errors;
  11. use Modules\Common\Exceptions\CommonBusinessException;
  12. /**
  13. * 巨量2.0事件-微信小程序
  14. */
  15. class JLEventController extends CatchController
  16. {
  17. use ValidatesRequests;
  18. /**
  19. * 回传配置列表
  20. * @param Request $request
  21. */
  22. public function list(Request $request) {
  23. $id = $request->input('id');
  24. $name = $request->input('name');
  25. $promotionId = $request->input('promotion_id');
  26. $unbind = $request->input('unbind', 0);
  27. $result = DB::table('jl_event_callback_config as config')
  28. ->leftJoin('promotions', 'promotions.callback_config_id', '=', 'config.id')
  29. ->where([
  30. 'user_id' => $this->getLoginUserId(),
  31. ])->when($id, function ($query, $id){
  32. return $query->where('config.id', $id);
  33. })->when($name, function ($query, $name){
  34. return $query->where('config.name', 'like', '%' .$name. '%');
  35. })->when($promotionId, function ($query, $promotionId){
  36. return $query->where('promotions.id', $promotionId)
  37. ->where('promotions.callback_type' , CallbackConst::TYPE_JL_EVENT_20);
  38. })->when(1 == $unbind, function ($query){
  39. return $query->whereNull('promotions.id');
  40. })
  41. ->select('config.id', 'config.name', 'config.charge_type', 'config.updated_at',
  42. 'promotions.name as promotion_name', 'promotions.id as promotion_id',
  43. 'config.charge_money_map', 'config.is_roi')
  44. ->orderBy('id', 'desc')
  45. ->paginate($request->input('limit', 15));
  46. foreach ($result as $item){
  47. $item->charge_type_str = CallbackConst::CHARGE_TYPE_MAP[$item->charge_type] ?? '-';
  48. $item->charge_money_map = \json_decode($item->charge_money_map) ?? [];
  49. }
  50. return $result;
  51. }
  52. /**
  53. * 新增回传配置
  54. * @param Request $request
  55. */
  56. public function add(Request $request) {
  57. $this->validate($request, [
  58. 'name' => 'required|string|max:64',
  59. // roi 全量上报:1-全量上报,2-不全量上报
  60. 'is_roi' => 'required|integer|in:1,2',
  61. // 充值行为:1-首充,2-所有充值
  62. 'charge_type' => 'required_if:is_roi,2|integer|in:1,2',
  63. // 金额项
  64. 'charge_money_map' => 'required_if:is_roi,2|array',
  65. 'charge_money_map.*.min_money' => 'integer|min:0',
  66. ]);
  67. if(2 == $request->input('is_roi') &&
  68. (!JLEventService::judgeChargeMoneyOk($request->input('charge_money_map')))) {
  69. CommonBusinessException::throwError(Errors::CALLBACK_CHARGE_MONEY_MAP_ERROR);
  70. }
  71. $userId = $this->getLoginUserId();
  72. $model = JLEventCallbackConfigModel::create(array_merge($request->only('name', 'is_roi', 'charge_type'), [
  73. 'charge_money_map' => \json_encode($request->input('charge_money_map')),
  74. 'user_id' => $userId,
  75. ]));
  76. JLEventService::saveRateConfigLog($userId, $model->id, $request->input('charge_money_map', []));
  77. return 'ok';
  78. }
  79. /**
  80. * 更新回传配置
  81. * @param Request $request
  82. */
  83. public function update(Request $request) {
  84. $this->validate($request, [
  85. 'ids' => 'required|array',
  86. 'ids.*' => 'integer',
  87. // roi 全量上报:1-全量上报,2-不全量上报
  88. 'is_roi' => 'required|integer|in:1,2',
  89. // 充值行为:1-首充,2-所有充值
  90. 'charge_type' => 'required_if:is_roi,2|integer|in:1,2',
  91. // 金额项
  92. 'charge_money_map' => 'required_if:is_roi,2|array',
  93. 'charge_money_map.*.min_money' => 'integer|min:0',
  94. ]);
  95. if(1 == count($request->input('ids'))) {
  96. $updateData = $request->only('is_roi', 'charge_type', 'name');
  97. } else {
  98. $updateData = $request->only('is_roi', 'charge_type');
  99. }
  100. $now = date('Y-m-d H:i:s');
  101. $userId = $this->getLoginUserId();
  102. $configIds = DB::table('jl_event_callback_config')
  103. ->whereIn('id', $request->input('ids'))
  104. ->where('user_id', $userId)
  105. ->select('id')->get()->pluck('id');
  106. DB::table('jl_event_callback_config')
  107. ->whereIn('id', $configIds)
  108. ->update(array_merge($updateData, [
  109. 'charge_money_map' => \json_encode($request->input('charge_money_map', [])),
  110. 'updated_at' => $now,
  111. ]));
  112. foreach ($configIds as $configId) {
  113. JLEventService::saveRateConfigLog($userId, $configId, $request->input('charge_money_map', []));
  114. }
  115. return 'ok';
  116. }
  117. }