| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 | <?phpnamespace Modules\Tuiguang\Http\Controllers;use Catch\Base\CatchController;use Illuminate\Foundation\Validation\ValidatesRequests;use Illuminate\Http\Request;use Illuminate\Support\Facades\DB;use Modules\Common\Errors\Errors;use Modules\Common\Exceptions\CommonBusinessException;use Modules\User\Http\Controllers\UserTrait;class PromotionController extends CatchController{    use UserTrait;    use ValidatesRequests;    public function list(Request $request) {        $callbackTypeMap = [            '0' => '无',            '1' => '巨量账户级回传',        ];        $linkSourceMap = [            '0' => '',            '1' => 'tiktok'        ];        $name = $request->input('name');        $isConfig = $request->input('is_config', 1);        $id = $request->input('id');        $videoName = $request->input('video_name');        $starTime = $request->input('start_time');        $endTime = $request->input('end_time');        $miniprogramId = $request->input('miniprogram_id');        $result = DB::table('promotions')            ->leftJoin('videos', 'videos.id', '=', 'promotions.video_id')            ->where(['promotions.is_enabled' => 1, 'promotions.uid' => $this->getLoginUserId()])            ->when($miniprogramId, function ($query, $miniprogramId) {                return $query->where('promotions.miniprogram_id', $miniprogramId);            })            ->when($isConfig, function ($query) {                return $query->where('promotions.callback_config_id', '<>', 0);            }, function ($query) {                return $query->where('promotions.callback_config_id', 0);            })->when($name, function ($query, $name){                return $query->where('promotions.name', 'like', '%'. $name . '%');            })->when($id, function ($query, $id) {                return $query->where('promotions.id', $id);            })->when($videoName, function ($query, $videoName) {                return $query->where('videos.name', 'like', '%'. $videoName . '%');            })->when($starTime, function ($query, $startTime) {                return $query->where('promotions.created_at', '>=', $startTime);            })->when($endTime, function ($query, $endTime){                return $query->where('promotions.created_at', '<=', $endTime . ' 23:59:59');            })->orderBy('created_at', 'desc')            ->select('promotions.id', 'promotions.name', 'promotions.created_at',            'videos.name as video_name', 'promotions.series_sequence', 'promotions.callback_type',                'promotions.callback_config_id', 'promotions.video_id', 'promotions.remark')            ->paginate($request->input('limit', 15));        foreach ($result as $item) {            $item->series_sequence_name = '第'. $item->series_sequence . '集';            $item->callback_type_str = $callbackTypeMap[$item->callback_type] ?? '';            $item->promotion_path = config('tuiguang.tuiguang.url') . DIRECTORY_SEPARATOR . 'api/promotion/index?ranse_id='. $item->id;            $item->track_url = config('tuiguang.tuiguang.trackUrl') .                '/track?dycallback=1&connection_id='.$item->id.                '&link_source=' .( $linkSourceMap[$item->callback_type] ?? '') .                '&adid=__AID__&cid=__CID__&imei=__IMEI__&oaid=__OAID__&mac=__MAC__&os=__OS__&ip=__IP__&androidid=__ANDROIDID__&ua=__UA__×tamp=__TS__&callback_url=__CALLBACK_URL__&projectid=__PROJECT_ID__&promotionid=__PROMOTION_ID__&advertiser_id=__ADVERTISER_ID__&campaign_id=__CAMPAIGN_ID__';        }        return $result;    }    public function delete(Request $request) {        $this->validate($request, ['id' => 'required']);        DB::table('promotions')            ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])            ->update(['is_enabled' => 0, 'updated_at' => date('Y-m-d H:i:s')]);        return 'ok';    }    public function updateSeriesSequence(Request $request) {        $this->validate($request, ['id' => 'required',            'series_sequence' => 'required', 'remark' => 'nullable|string|max:140']);        DB::table('promotions')            ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])            ->update(['series_sequence' => $request->input('series_sequence'),                'remark' => $request->input('remark', ''),                'updated_at' => date('Y-m-d H:i:s')]);        return 'ok';    }    public function add(Request $request) {        $this->validate($request, [            'video_id' => 'required',            'series_sequence' => 'required',            'name' => 'required',            'miniprogram_id' => 'required',        ]);        $now = date('Y-m-d H:i:s');        DB::table('promotions')            ->insert([                'uid' => $this->getLoginUserId(),                'miniprogram_id' => $request->input('miniprogram_id'),                'name' => $request->input('name'),                'video_id' => $request->input('video_id'),                'series_sequence' =>  $request->input('series_sequence'),                'created_at' => $now,                'updated_at' => $now,            ]);        return 'ok';    }    /**     * 更新推广的回传配置     * 1, 如果是巨量账户级,推广id和巨量账户唯一绑定     * @param Request $request     * @return string     * @throws \Illuminate\Validation\ValidationException     */    public function updateCallbackConfig(Request $request) {        $this->validate($request, [            'id' => 'required',            'callback_type' => 'required|in:1',            'callback_config_id' => 'required',            'remark' => 'nullable|string|max:140',        ]);        if(1 == $request->input('callback_type')) {            $exist = DB::table('promotions')                ->where(['is_enabled' => 1, 'callback_type' => $request->input('callback_type'),                    'callback_config_id' => $request->input('callback_config_id')])                ->first();            if($exist && $exist->id != $request->input('id')) {                CommonBusinessException::throwError(Errors::JULIANG_ACCOUNT_PROMOTION_UNIQUE);            }        }        DB::table('promotions')            ->where(['id' => $request->input('id'), 'uid' => $this->getLoginUserId(), 'is_enabled' => 1])            ->update([                'callback_type' => $request->input('callback_type'),                'callback_config_id' => $request->input('callback_config_id'),                'remark' => $request->input('remark', ''),                'updated_at' => date('Y-m-d')            ]);        return 'ok';    }}
 |