protected function forCasApplicationList($what) { $where['a.is_complete'] = 1; $where['a.is_del'] = 0; $where['a.a_no'] = array('EXP', 'IS NOT NULL'); $where['b.lang'] = 'en-us'; $where['a.c_status'] = array('GT', 0); //通过部门查询学生 if ($what['department'] != "") { $id = M('agent_part')->where(array('name' => $what['department']))->getField('id'); $uid = M('user_agent')->field('uid')->where(array('partID' => $id))->select(); if ($uid) { foreach ($uid as $rs) { $uidList[] = $rs['uid']; } $where['a.uid'] = array('IN', $uidList); } else { $where['a.uid'] = 0; } } //通过编辑时间查询学生 if ($what['startTime'] != "") { $makeTime = explode('/', $what['startTime']); $startTime = strtotime($makeTime[2] . $makeTime[1] . $makeTime[0] . ' 0:0:0'); } if ($what['endTime'] != "") { $makeTime = explode('/', $what['endTime']); $endTime = strtotime($makeTime[2] . $makeTime[1] . $makeTime[0] . ' 23:59:59'); } if ($startTime != "" && $endTime == '') { $where['a.e_time'] = array('EGT', $startTime); } if ($startTime == "" && $endTime != '') { $where['a.e_time'] = array('BETWEEN', array('1', $endTime)); } if ($startTime != "" && $endTime != '') { $where['a.e_time'] = array('BETWEEN', array($startTime, $endTime)); } //根据姓查询申请学生 if ($what['family_name'] != "") { $where['a.family_name'] = array('like', '%' . $what['family_name'] . '%'); } //根据名查询申请学生 if ($what['first_name'] != "") { $where['a.first_name'] = array('like', '%' . $what['first_name'] . '%'); } //根据申请编号查询申请学生 if ($what['reference'] != "") { $where['a.reference'] = array('like', $what['reference']); } //通过学校查询申请单 if ($what['university'] != "") { $us_id = M('universitylang')->where(array('name' => array("LIKE", "%" . $what['university'] . "%")))->getField('fid'); if ($us_id != "") { $where['a.us_id'] = $us_id; } else { $where['a.us_id'] = 0; } } //查询无效单 if ($what['invalid'] == 1) { $where['a.invalid'] = 1; } //初始状态设置 $this->assign('what', $what); // 有读取权限的部门列表 $allowDepts = AgentAuth::getAllowParts(['r']); $partInfo = []; // 有权限操作的部门键值对 id => name foreach ($allowDepts as $row) { $partInfo[$row['id']] = $row['name']; } unset($allowDepts); $ids = array_keys($partInfo); if (!empty($ids)) { $map['a.uid'] = session('uid'); $map['a.partid'] = array('IN', $ids); $map['_logic'] = 'or'; $where['_complex'] = $map; } else { $where['a.uid'] = session('uid'); } return $where; }
/** * 上传的图像列表. * * @access public * @return void * @author Liuping <*****@*****.**> */ public function filesList($id) { // 学生 id $studentId = intval($id); // 没有 学生 id if (empty($studentId)) { $this->error('Invalid parameters'); } // 实例化模型 $model = new MemberStuModel(); // 学生基本信息 $stuInfo = $model->fetchStuInfo($studentId); if (empty($stuInfo)) { $this->error('Invalid parameters'); } // 对学生做权限验证 $res = AgentAuth::checkStu($studentId, [AgentAuth::READ]); if (9 !== $res['status']) { $this->error('No permission'); } // 上传信息 $uploadInfo = $model->fetchUploadInfo($stuInfo['id'], ''); if (empty($uploadInfo)) { $this->error('Invalid parameters'); } $this->assign('uploadInfo', $uploadInfo); $this->display(); }
/** * 提交申请第 3 步处理. * * @access public * @return void * @author Liuping <*****@*****.**> */ public function appSubmit3Action() { // 校验一级中介是否有权限添加申请 if (!AgentAuth::checkTopAgentOfApply()) { $this->error('No permission'); } // 申请 id $appStatusId = intval(I('post.appStatus', '')); // 陈述内容 $stateContent = I('post.stateText', ''); if (empty($appStatusId)) { $this->error('Parameters error', U('Student/noApplyStudentList')); } $modelAppStatus = new ApplyStatusModel(); $appStatusInfo = $modelAppStatus->find($appStatusId); if (NULL === $appStatusInfo || FALSE === $appStatusInfo) { $appStatusInfo = []; } if (empty($appStatusInfo)) { $this->error('Parameters error', U('Student/noApplyStudentList')); } // 操作类型 1 : 添加, 2 : 编辑 $operFlag = intval(I('post.oper', 1)); // 根据操作类型, 设置不同的权限 $authRule = []; if (1 === $operFlag) { $authRule[] = AgentAuth::ADD; } else { $authRule[] = AgentAuth::WRITE; } $modelStu = new MemberStuModel(); // 验证权限 $res = AgentAuth::checkStu($appStatusInfo['s_no'], $authRule); if ($res['status'] !== 9) { $this->error('No permission'); } // 申请状态 $applyStatus = intval($appStatusInfo['a_status']); // 若申请状态为材料出错(a_status : 2), 就不验证是否超过允许添加的条数和不更新申请数量 $res = FALSE; // 默认为未超过申请条数 if (2 !== $applyStatus) { // 检查是否已超过允许添加的条数 $res = $modelAppStatus->checkApplyNum($appStatusInfo['year'], $appStatusInfo['s_no']); } if ($res) { // 超过申请次数跳转到中介未申请学生列表 $msg = 'The application amount of ' . $appStatusInfo['year'] . 'entry for this student has run out.'; $this->error($msg, U('Student/noApplyStudentList')); } // 开始组装新添加的数据 $uid = $appStatusInfo['uid']; $fuid = $appStatusInfo['fuid']; $partid = $appStatusInfo['partid']; $stuId = $appStatusInfo['s_no']; $ano = $appStatusInfo['a_no']; // 个人陈述 $perStateInfo = $modelStu->fetchPerStateInfo($stuId, $ano); if (empty($perStateInfo)) { // 新增 $perStateInfo = $modelStu->fetchPerStateInfo($stuId, ''); $perStateInfo['id'] = ''; $perStateInfo['uid'] = $uid; $perStateInfo['fuid'] = $fuid; $perStateInfo['partid'] = $partid; $perStateInfo['s_id'] = $stuId; $perStateInfo['a_no'] = $ano; $perStateInfo['create_time'] = time(); } // 陈述内容 $perStateInfo['content'] = $stateContent; // 执行验证规则 $res = $modelStu->validate($modelStu->perStateRules)->create($perStateInfo); if (!$res) { $this->error($modelStu->getError()); } $modelStu->startTrans(); // 开启事务 $res = $modelStu->procPerStateInfo($perStateInfo, $uid, $stuId, $ano); $res1 = $modelAppStatus->switchCompleteStatus($appStatusId, 1, time()); $stuFullName = $appStatusInfo['first_name'] . ' ' . $appStatusInfo['family_name']; // 若申请状态为材料出错(a_status : 2), 就不验证是否超过允许添加的条数和不更新申请数量 $res2 = TRUE; // 默认为更新数量成功 if (2 !== $applyStatus) { $res2 = $modelAppStatus->updateApplyNum($appStatusInfo['year'], $stuId, $stuFullName); } $aoInfo = $modelStu->fetchAoInfo($stuId); $res3 = $modelAppStatus->switchApplyStatus($appStatusId, 1); // 更新状态为 审核中. $res4 = TRUE; $res5 = TRUE; $res6 = TRUE; $_cont = '用户重新提交了申请'; $_cont1 = 'Application has been resubmitted, application status changes to"Verifying by ApplicationUK"'; if (!empty($aoInfo) && 2 === $applyStatus) { // 有跟进AO且状态是材料出错, 就记录日志 $res4 = $modelStu->writeLog($aoInfo['ao_uid'], $uid, $ano, 1, date('Y-m-d H:i:s') . ', ' . $_cont); $res5 = $modelStu->writeApplyLog($aoInfo['ao_uid'], $uid, $ano, 1, $_cont1); } // 新申请记录新申请日志. if (0 === $applyStatus) { $_cont1 = 'Your application has been submitted and now under verification, application status changes to "Verifing by ApplicationUK"'; $res6 = $modelStu->writeApplyLog(empty($aoInfo) ? 0 : $aoInfo['ao_uid'], $uid, $ano, 1, $_cont1); } if ($res && $res1 && $res2 && $res3 && $res4 && $res5 && $res6) { $modelStu->commit(); if (!empty($aoInfo) && 2 === $applyStatus) { // 材料出错重新提交, 给 AO 发邮件 $resubmitTime = date('Y-m-d H:i:s', time()); $emailTitle = $stuFullName . ' ' . $_cont; $emailContent = <<<MAIL 学生姓名: {$stuFullName}. 提交时间: {$resubmitTime}. 描述: {$_cont}. MAIL; // 发送邮件 MemberStuModel::sendEmail($aoInfo['ao_user_email'], $emailTitle, $emailContent); } elseif (!empty($aoInfo)) { // 新添加/修改申请时要发邮件 $_cont = '提交了新的申请'; $resubmitTime = date('Y-m-d H:i:s', time()); $emailTitle = $stuFullName . ' ' . $_cont; $emailContent = <<<MAIL 学生姓名: {$stuFullName}. 提交时间: {$resubmitTime}. 描述: {$_cont}. MAIL; // 发送邮件 MemberStuModel::sendEmail($aoInfo['ao_user_email'], $emailTitle, $emailContent); } // 写入系统日志 $_mark = session('username') . '在' . date('Y-m-d H:i:s') . ', 添加了一个申请资料, 申请编号 : ' . $ano . ', 学生姓名 : ' . $appStatusInfo['first_name'] . $appStatusInfo['family_name']; if (1 === $operFlag) { // 写入新增日志 system_log($_mark, $modelAppStatus->getTableName(), $ano, 'a', $appStatusInfo, NULL, 1); } // 成功跳转到已申请列表. //$this->success('Successful!', U('Student/studentList')); $this->success('Successful!', U('Student/studentDetail', ['id' => $stuId])); } else { $modelStu->rollback(); $this->error('Action failed'); } }