deal($data)) { $job->delete(); return true; } if ($job->attempts() >= 3) { $job->delete(); return false; } $job->release(10); //10秒后重试 } /** * 处理业务逻辑 * @param type $data * @return bool */ public function deal($data): bool { switch ($data["type"]) { case 1: //部门超时驳回 $mainId = $data["id"]; $where[] = ["ti.id", "=", $mainId]; $where[] = ["ti.checkState", "=", TalentState::FST_VERIFY_PASS]; $where[] = ["ti.pass_dept_check", "=", 0]; $talent_info = TalentModel::alias("ti") ->leftJoin("new_talent_condition tc", "tc.id=ti.talent_condition") ->leftJoin("un_enterprise e", "e.id=ti.enterprise_id") ->leftJoin("(select description,mainId,last_state,new_state,state,createTime from new_talent_checklog where md5(concat(createTime,mainId,`type`)) in (select md5(concat(max(createTime),mainId,`type`)) from `new_talent_checklog` where `type`=1 and `step` is null and active=1 and typeFileId is null group by mainId,`type`)) tl", "`tl`.`mainId`=ti.id") ->where($where)->field("ti.*,tc.companyIds,tc.companyWithFileType")->find(); if ($talent_info) { $weekDay = date("w"); //0周日,6周六 if ($weekDay == 6) { $delay = 2 * 24 * 3600; queue("app\job\Talent", ["type" => 1, "id" => $mainId], $delay); return true; } if (!$weekDay || $weekDay == 0) { $delay = 1 * 24 * 3600; queue("app\job\Talent", ["type" => 1, "id" => $mainId], $delay); return true; } $modify_files = array_filter(explode(",", $talent_info["modify_files"])); $companyAndTypes = []; $companyWithFileType = array_filter(explode(";", $talent_info["companyWithFileType"])); foreach ($companyWithFileType as $c) { list($companyId, $fileTypesStr) = array_filter(explode(":", $c)); $companyAndTypes[$companyId] = array_filter(explode(",", $fileTypesStr)); } $companyIds = array_filter(explode(",", $talent_info["companyIds"])); if ($companyIds) { if ($talent_info["re_check_companys"]) { $unpass_companyIds = array_filter(explode(",", $talent_info["re_check_companys"])); } else { //这边去除已经审核通过的单位,主要通过日志是否存在记录。 $pass_companyIds = TalentLogApi::getPassDepts($talent_info["id"]); //已经通过的单位 $unpass_companyIds = array_diff($companyIds, (array) $pass_companyIds); //排除已经通过的单位 } if (!$unpass_companyIds) { //没有未审部门 return true; } //开始驳回操作 $fst_dept_check_time = $talent_info["first_dept_check_time"]; $log_checkState = TalentState::FST_VERIFY_PASS; //当前状态不变 $checkState = TalentState::SCND_SUBMIT; //退回待初审 foreach ($unpass_companyIds as $companyId) { $fileTypes = $companyAndTypes[$companyId]; $modify_files = array_unique((array_merge((array) $modify_files, (array) $fileTypes))); $dept_log = TalentLogApi::getLogByCompanyId($talent_info["id"], $companyId, $fst_dept_check_time); TalentLogApi::rewrite($dept_log["id"], [$log_checkState, $checkState], "审核超时,系统自动驳回"); } $log_checkState = TalentState::DEPT_VERIFY_REJECT; $data["id"] = $talent_info["id"]; $data["modify_files"] = implode(",", $modify_files); $data["checkState"] = $checkState; $data["first_dept_check_time"] = null; $data["re_check_companys"] = null; TalentModel::update($data); TalentLogApi::write(1, $talent_info["id"], [$log_checkState, $checkState], "审核超时,系统自动驳回,部门审核结束", 1); } return true; } break; } return false; } }