예제 #1
0
 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;
 }
예제 #2
0
 /**
  * 上传的图像列表.
  * 
  * @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
0
    /**
     * 提交申请第 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');
        }
    }