| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273 | <?phpnamespace Modules\Callback\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 JuliangAccountController extends CatchController{    use UserTrait;    use ValidatesRequests;    public function list(Request $request) {        $advAccountId = $request->input('account_id');        $advAccountName = $request->input('account_name');        return DB::table('juliang_account_callback_config')            ->where(['company_uid' => $this->getOptimizerUid()])            ->when($advAccountId, function ($query, $advAccountId) {                return $query->where('adv_account_id' , $advAccountId);            })->when($advAccountName, function ($query, $advAccountName) {                return $query->where('adv_account_name', 'like', '%'. $advAccountName. '%');            })            ->paginate($request->input('limit', 30));    }    public function addAccount(Request $request) {        $this->validate($request, [            'account_id' => 'required',            'account_name' => 'required|string|max:64',            'state' => 'required|integer|in:0,1',            'protect_num' => 'required|integer|min:0',            'default_rate' => 'required|min:0|max:100',            'rate_time_config' => 'nullable|array',            'min_money' => 'required|min:0',            'max_money' => 'required|min:0'        ]);        if(DB::table('juliang_account_callback_config')            ->where(['company_uid' => $this->getOptimizerUid(), 'adv_account_id' => $request->input('account_id')])            ->exists()) {            CommonBusinessException::throwError(Errors::JULIANG_ACCOUNT_EXISTS);        }        if($request->input('rate_time_config') &&            !$this->is_time_cross($request->input('rate_time_config'))) {            CommonBusinessException::throwError(Errors::CALLBACK_RATE_TIME_RANGE_ERROR);        }        $now = date('Y-m-d H:i:s');        DB::table('juliang_account_callback_config')            ->insert([                'adv_account_id' => $request->input('account_id'),                'adv_account_name' => $request->input('account_name'),                'state' => $request->input('state'),                'protect_num' => $request->input('protect_num'),                'default_rate' => $request->input('default_rate'),                'rate_time_config' => \json_encode($request->input('rate_time_config', [])),                'min_money' => $request->input('min_money'),                'max_money' => $request->input('max_money'),                'company_uid' => $this->getOptimizerUid(),                'created_at' => $now,                'updated_at' => $now,            ]);        DB::table('juliang_account_rate_config_log')            ->insert([                'company_uid' => $this->getOptimizerUid(),                'account_id' => $request->input('account_id'),                'config_per' => $request->input('default_rate'),                'created_at' => $now,                'updated_at' => $now,            ]);        if($request->input('rate_time_config')) {            $this->saveTimeConfig($this->getOptimizerUid(), $request->input('account_id'), $request);        }        return 'ok';    }    public function updateCallbackConfig(Request $request) {        $this->validate($request, [            'ids' => 'required|array',            'state' => 'required|integer|in:0,1',            'protect_num' => 'required|integer|min:0',            'default_rate' => 'required|min:0|max:100',            'rate_time_config' => 'nullable|array',            'min_money' => 'required|min:0',            'max_money' => 'required|min:0'        ]);        if($request->input('callback_rate_time_config') &&            !$this->is_time_cross($request->input('rate_time_config'))) {            CommonBusinessException::throwError(Errors::CALLBACK_RATE_TIME_RANGE_ERROR);        }        $now = date('Y-m-d H:i:s');        foreach ($request->input('ids') as $id) {            DB::table('juliang_account_callback_config')                ->where(['id' => $id, 'company_uid' => $this->getOptimizerUid()])                ->update([                    'state' => $request->input('state'),                    'protect_num' => $request->input('protect_num'),                    'default_rate' => $request->input('default_rate'),                    'rate_time_config' => \json_encode($request->input('rate_time_config', [])),                    'min_money' => $request->input('min_money'),                    'max_money' => $request->input('max_money'),                    'updated_at' => $now,                ]);        }        $advAccountIds = DB::table('juliang_account_callback_config')            ->whereIn('id', $request->input('ids'))            ->where('company_uid', $this->getOptimizerUid())            ->select('adv_account_id')->get()->pluck('adv_account_id');        if($advAccountIds->isNotEmpty()) {            DB::table('juliang_account_rate_config_log')                ->where('company_uid', $this->getOptimizerUid())                ->whereIn('account_id', $advAccountIds)                ->where('is_enabled', 1)                ->update(['is_enabled' => 0, 'updated_at' => $now]);            DB::table('juliang_account_promotion_protect_record')                ->where('optimizer_uid', $this->getOptimizerUid())                ->whereIn('advertiser_id', $advAccountIds)                ->where('is_enabled', 1)                ->update(['is_enabled' => 0, 'updated_at' => $now]);            foreach ($advAccountIds as $accountId) {                DB::table('juliang_account_rate_config_log')                    ->insert([                        'company_uid' => $this->getOptimizerUid(),                        'account_id' => $accountId,                        'config_per' => $request->input('default_rate'),                        'created_at' => $now,                        'updated_at' => $now,                    ]);                $this->saveTimeConfig($this->getOptimizerUid(), $accountId, $request);            }        }        return 'ok';    }    /**     * 判断时 设置的时间范围是否有交集     *     * @param string $config_time 开始时间1     * @return bool     */    protected  function is_time_cross($config_time) {        $timeline = [];        foreach ($config_time as $key => $value) {            $start_time = $value['start_time'];            $start = explode(':', $start_time);            $cur_start = (int)$start[0] * 60 + $start[1];            $end_time = $value['end_time'];            $end = explode(':', $end_time);            $cur_end = (int)$end[0] * 60 + $end[1];            if ($cur_end <= $cur_start) {                return false;            }            if ($timeline) {                foreach ($timeline as $k => $v) {                    if ($cur_start >= $v['start'] && $cur_start <= $v['end']) {                        return false;                    }                    if ($cur_end >= $v['start'] && $cur_end <= $v['end']) {                        return false;                    }                }            }            $timeline[] = ['start'=>$cur_start,'end'=>$cur_end];        }        return true;    }    public  function saveTimeConfig($companyUid, $accountId, $configInfo )    {        DB::table('juliang_account_promotion_config_time')            ->where('is_enable',1)            ->where('company_uid',$companyUid)            ->where('account_id',$accountId)->update(['is_enable'=>0]);        $time_config = $configInfo['rate_time_config'];        if (empty($time_config)) {            return false;        }        $is = $this->is_time_cross($time_config);        if (!$is) {            return false;        }        $data = [];        $temp['company_uid'] = $companyUid;        $temp['account_id'] = $accountId;        $temp['other_data']['default_rate'] = $configInfo['default_rate'];        $temp['other_data']['min_money'] = $configInfo['min_money'];        $temp['other_data']['max_money'] = $configInfo['max_money'];        $temp['other_data']['protect_num'] = $configInfo['protect_num'];        $temp['other_data']['state'] = $configInfo['state'];        $temp['other_data'] = json_encode($temp['other_data']);        $temp['next_exec_time'] = date('Y-m-d');        $temp['is_enable'] = 1;        $temp['created_at'] = date('Y-m-d H:i:s',time());        foreach ($time_config as $value) {            $start_time = $value['start_time'];            $end_time = $value['end_time'];            $temp['config_time'] = $start_time;            $temp['config_per'] = $value['config_per'];            $data[] = $temp;            //结束后 百分比改为默认的            $temp['config_time'] = $end_time;            $temp['config_per'] = $configInfo['default_rate'];            $data[] = $temp;        }        //插入设置最新的时间段百分比        DB::table('juliang_account_promotion_config_time')->insert($data);    }    /**     * 回传开关     * @param Request $request     * @throws \Illuminate\Validation\ValidationException     */    public function turnCallbackState(Request $request) {        $this->validate($request, ['state' => 'required|integer|in:0,1',            'id' => 'required']);        $now = date('Y-m-d H:i:s');        $config = DB::table('juliang_account_callback_config')            ->where([                'id' => $request->input('id'),                'company_uid' => $this->getOptimizerUid(),            ])->first();        if(!$config) {            CommonBusinessException::throwError(Errors::JULIANG_ACCOUNT_CONFIG_NOT_EXISTS);        }        DB::table('juliang_account_callback_config')            ->where('id', $request->input('id'))            ->update([                'state' => $request->input('state'),                'updated_at' => $now            ]);        if(1 == $request->input('state')) {            DB::table('juliang_account_rate_config_log')                ->where('company_uid', $this->getOptimizerUid())                ->where('account_id', $config->adv_account_id)                ->where('is_enabled', 1)                ->update(['is_enabled' => 0, 'updated_at' => $now]);            DB::table('juliang_account_promotion_protect_record')                ->where('optimizer_uid', $this->getOptimizerUid())                ->where('advertiser_id', $config->adv_account_id)                ->where('is_enabled', 1)                ->update(['is_enabled' => 0, 'updated_at' => $now]);            DB::table('juliang_account_rate_config_log')                ->insert([                    'company_uid' => $this->getOptimizerUid(),                    'account_id' => $config->adv_account_id,                    'config_per' => $config->default_rate,                    'created_at' => $now,                    'updated_at' => $now,                ]);            // 让所有的时间区间比例配置,在定时任务中,重新执行一遍            DB::table('juliang_account_promotion_config_time')                ->where('is_enable',1)                ->where('company_uid',$this->getOptimizerUid())                ->where('account_id',$config->adv_account_id)                ->update(['next_exec_time' => date('Y-m-d'), 'updated_at' => $now]);        }        return 'ok';    }}
 |