Merge branch 'driver'
This commit is contained in:
commit
ae4d5c2432
@ -68,7 +68,6 @@ public interface IInspectionFileService extends IService<InspectionFile> {
|
|||||||
/**
|
/**
|
||||||
* 分页查询 InspectionFile 列表
|
* 分页查询 InspectionFile 列表
|
||||||
*
|
*
|
||||||
* @param page 分页对象
|
|
||||||
* @param inspectionFile 查询条件
|
* @param inspectionFile 查询条件
|
||||||
* @return 分页结果
|
* @return 分页结果
|
||||||
*/
|
*/
|
||||||
|
@ -209,4 +209,13 @@ public class DriveSchoolCoachClockController {
|
|||||||
return success(coachClockService.getClockCarInfoByUserId(userId, carNo));
|
return success(coachClockService.getClockCarInfoByUserId(userId, carNo));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GetMapping("/errorPage")
|
||||||
|
@Operation(summary = "获得教练异常打卡记录分页")
|
||||||
|
public CommonResult<IPage<?>> queryErrorClockListPage(DriveSchoolCoachClockVO pageReqVO,
|
||||||
|
@RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo,
|
||||||
|
@RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) {
|
||||||
|
Page<DriveSchoolCoachClockVO> page = new Page<>(pageNo, pageSize);
|
||||||
|
return success(coachClockService.queryErrorClockListPage(pageReqVO, page));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -253,6 +253,14 @@ public class TrainController {
|
|||||||
return success(trainService.getTrainStudentList(coachClockId));
|
return success(trainService.getTrainStudentList(coachClockId));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据教练打卡id,获取对应异常学员列表信息
|
||||||
|
*/
|
||||||
|
@GetMapping("getTrainErrorStudentList")
|
||||||
|
public CommonResult<List<Train>> getTrainErrorStudentList(@RequestParam(value = "coachClockId") String coachClockId){
|
||||||
|
return success(trainService.getTrainErrorStudentList(coachClockId));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取学员导出数据列表
|
* 获取学员导出数据列表
|
||||||
*/
|
*/
|
||||||
|
@ -63,5 +63,8 @@ public interface DriveSchoolCoachClockMapper extends BaseMapper<DriveSchoolCoach
|
|||||||
List<String> getClockCarNoByUserId(@Param("userId") Long userId);
|
List<String> getClockCarNoByUserId(@Param("userId") Long userId);
|
||||||
DriveSchoolCoachClock getClockCarInfoByUserId(@Param("userId") Long userId, @Param("carNo") String carNo);
|
DriveSchoolCoachClock getClockCarInfoByUserId(@Param("userId") Long userId, @Param("carNo") String carNo);
|
||||||
|
|
||||||
|
IPage<DriveSchoolCoachClockVO> queryErrorClockListPage(@Param("entity") DriveSchoolCoachClockVO pageReqVO, Page<DriveSchoolCoachClockVO> page);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -99,4 +99,12 @@ public interface IDriveSchoolCoachClockService extends IService<DriveSchoolCoach
|
|||||||
List<String> getClockCarNoByUserId(Long userId);
|
List<String> getClockCarNoByUserId(Long userId);
|
||||||
DriveSchoolCoachClock getClockCarInfoByUserId(Long userId, String carNo);
|
DriveSchoolCoachClock getClockCarInfoByUserId(Long userId, String carNo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获得教练异常打卡记录分页
|
||||||
|
* @param pageReqVO
|
||||||
|
* @param page
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
IPage<DriveSchoolCoachClockVO> queryErrorClockListPage(DriveSchoolCoachClockVO pageReqVO, Page<DriveSchoolCoachClockVO> page);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -98,6 +98,7 @@ public interface TrainService extends IService<Train> {
|
|||||||
* 根据教练打卡id,获取对应学员列表信息
|
* 根据教练打卡id,获取对应学员列表信息
|
||||||
*/
|
*/
|
||||||
List<Train> getTrainStudentList(String coachClockId);
|
List<Train> getTrainStudentList(String coachClockId);
|
||||||
|
List<Train> getTrainErrorStudentList(String coachClockId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取学员导出数据列表
|
* 获取学员导出数据列表
|
||||||
|
@ -466,5 +466,36 @@ public class DriveSchoolCoachClockServiceImpl extends ServiceImpl<DriveSchoolCoa
|
|||||||
return driveSchoolCoachClockMapper.getClockCarInfoByUserId(userId, carNo);
|
return driveSchoolCoachClockMapper.getClockCarInfoByUserId(userId, carNo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获得教练异常打卡记录分页
|
||||||
|
*
|
||||||
|
* @param pageReqVO
|
||||||
|
* @param page
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public IPage<DriveSchoolCoachClockVO> queryErrorClockListPage(DriveSchoolCoachClockVO pageReqVO, Page<DriveSchoolCoachClockVO> page) {
|
||||||
|
String startTime = "";
|
||||||
|
String endTime = "";
|
||||||
|
if ("more".equals(pageReqVO.getTimeType())) {
|
||||||
|
if (org.apache.commons.lang3.StringUtils.isNotEmpty(pageReqVO.getStartTimeStr())) {
|
||||||
|
startTime = pageReqVO.getStartTimeStr();
|
||||||
|
}
|
||||||
|
if (org.apache.commons.lang3.StringUtils.isNotEmpty(pageReqVO.getEndTimeStr())) {
|
||||||
|
endTime = pageReqVO.getEndTimeStr();
|
||||||
|
}
|
||||||
|
} else if ("month".equals(pageReqVO.getTimeType())) {
|
||||||
|
//当月
|
||||||
|
startTime = DateUtil.format(DateUtil.beginOfMonth(DateUtil.date()), "yyyy-MM-dd");
|
||||||
|
endTime = DateUtil.format(DateUtil.endOfMonth(DateUtil.date()), "yyyy-MM-dd");
|
||||||
|
} else if ("day".equals(pageReqVO.getTimeType())) {
|
||||||
|
//当天
|
||||||
|
startTime = DateUtil.formatDate(DateUtil.date());
|
||||||
|
endTime = DateUtil.formatDate(DateUtil.date());
|
||||||
|
}
|
||||||
|
pageReqVO.setStartTimeStr(startTime);
|
||||||
|
pageReqVO.setEndTimeStr(endTime);
|
||||||
|
return driveSchoolCoachClockMapper.queryErrorClockListPage(pageReqVO, page);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -205,6 +205,22 @@ public class TrainServiceImpl extends ServiceImpl<TrainMapper, Train> implements
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据教练打卡id,获取对应学员列表信息
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public List<Train> getTrainErrorStudentList(String coachClockId) {
|
||||||
|
return lambdaQuery().eq(Train::getCoachClockId,coachClockId)
|
||||||
|
.eq(Train::getDeleted,0)
|
||||||
|
.isNull(Train::getEndTime)
|
||||||
|
.isNotNull(Train::getUserId)
|
||||||
|
.isNotNull(Train::getCoachId)
|
||||||
|
.isNotNull(Train::getSubject)
|
||||||
|
.orderByDesc(Train::getCreateTime)
|
||||||
|
.list();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取学员导出数据列表
|
* 获取学员导出数据列表
|
||||||
|
@ -367,4 +367,35 @@
|
|||||||
AND subject = #{entity.subject}
|
AND subject = #{entity.subject}
|
||||||
</if>
|
</if>
|
||||||
</select>-->
|
</select>-->
|
||||||
|
|
||||||
|
|
||||||
|
<select id="queryErrorClockListPage" resultType="cn.iocoder.yudao.module.train.vo.DriveSchoolCoachClockVO">
|
||||||
|
SELECT
|
||||||
|
dscc.*
|
||||||
|
FROM
|
||||||
|
drive_school_coach_clock dscc
|
||||||
|
WHERE
|
||||||
|
dscc.end_time IS NULL
|
||||||
|
AND dscc.train_day < CURDATE()
|
||||||
|
AND dscc.deleted = 0
|
||||||
|
<if test="entity.userId!= null and entity.userId!= ''">
|
||||||
|
and dscc.user_id = #{entity.userId}
|
||||||
|
</if>
|
||||||
|
<if test="entity.carNo!= null and entity.carNo!= ''">
|
||||||
|
and dscc.car_no like concat('%', #{entity.carNo},'%')
|
||||||
|
</if>
|
||||||
|
<if test="entity.subject!= null and entity.subject!= ''">
|
||||||
|
and dscc.subject = #{entity.subject}
|
||||||
|
</if>
|
||||||
|
<if test="entity.id!= null and entity.id!= ''">
|
||||||
|
and dscc.id = #{entity.id}
|
||||||
|
</if>
|
||||||
|
<if test="entity.startTimeStr != null and entity.startTimeStr != ''">
|
||||||
|
AND dscc.train_day >= #{entity.startTimeStr}
|
||||||
|
</if>
|
||||||
|
<if test="entity.endTimeStr != null and entity.endTimeStr != ''">
|
||||||
|
AND dscc.train_day <= #{entity.endTimeStr}
|
||||||
|
</if>
|
||||||
|
ORDER BY dscc.train_day DESC
|
||||||
|
</select>
|
||||||
</mapper>
|
</mapper>
|
||||||
|
@ -151,7 +151,7 @@ public class SysLoginController {
|
|||||||
@TenantIgnore
|
@TenantIgnore
|
||||||
public CommonResult loginApp(@RequestBody LoginBody loginBody) throws Exception {
|
public CommonResult loginApp(@RequestBody LoginBody loginBody) throws Exception {
|
||||||
String userName = loginBody.getUsername();
|
String userName = loginBody.getUsername();
|
||||||
AdminUserDO user = userService.getUserByUsername(userName);
|
AdminUserDO user = userService.getUserByUsernameRescue(userName);
|
||||||
if (ObjectUtil.isEmpty(user)) {
|
if (ObjectUtil.isEmpty(user)) {
|
||||||
return error(CommonErrorCodeConstants.LOGIN_ACCOUNT_NOT_EXIST);
|
return error(CommonErrorCodeConstants.LOGIN_ACCOUNT_NOT_EXIST);
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,8 @@ package cn.iocoder.yudao.module.bpm.framework.web.core;
|
|||||||
|
|
||||||
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
|
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
|
||||||
import cn.iocoder.yudao.module.bpm.framework.flowable.core.util.FlowableUtils;
|
import cn.iocoder.yudao.module.bpm.framework.flowable.core.util.FlowableUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.web.filter.OncePerRequestFilter;
|
import org.springframework.web.filter.OncePerRequestFilter;
|
||||||
|
|
||||||
import javax.servlet.FilterChain;
|
import javax.servlet.FilterChain;
|
||||||
@ -17,6 +19,8 @@ import java.io.IOException;
|
|||||||
*/
|
*/
|
||||||
public class FlowableWebFilter extends OncePerRequestFilter {
|
public class FlowableWebFilter extends OncePerRequestFilter {
|
||||||
|
|
||||||
|
private static final Logger log = LoggerFactory.getLogger(FlowableWebFilter.class);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
|
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
|
||||||
throws ServletException, IOException {
|
throws ServletException, IOException {
|
||||||
@ -24,13 +28,23 @@ public class FlowableWebFilter extends OncePerRequestFilter {
|
|||||||
// 设置工作流的用户
|
// 设置工作流的用户
|
||||||
Long userId = SecurityFrameworkUtils.getLoginUserId();
|
Long userId = SecurityFrameworkUtils.getLoginUserId();
|
||||||
if (userId != null) {
|
if (userId != null) {
|
||||||
|
try {
|
||||||
FlowableUtils.setAuthenticatedUserId(userId);
|
FlowableUtils.setAuthenticatedUserId(userId);
|
||||||
|
} catch (Exception e) {
|
||||||
|
// 忽略设置用户 ID 时的异常,避免影响主流程
|
||||||
|
log.warn("设置 Flowable 认证用户 ID 失败", e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// 过滤
|
// 过滤
|
||||||
chain.doFilter(request, response);
|
chain.doFilter(request, response);
|
||||||
} finally {
|
} finally {
|
||||||
// 清理
|
// 清理
|
||||||
|
try {
|
||||||
FlowableUtils.clearAuthenticatedUserId();
|
FlowableUtils.clearAuthenticatedUserId();
|
||||||
|
} catch (Exception e) {
|
||||||
|
// 忽略清理时的异常
|
||||||
|
log.warn("清理 Flowable 认证用户 ID 失败", e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@ import cn.iocoder.yudao.module.system.controller.admin.auth.vo.AuthLoginReqVO;
|
|||||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.user.UserPageReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.user.vo.user.UserPageReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.app.user.UserInfoVO;
|
import cn.iocoder.yudao.module.system.controller.app.user.UserInfoVO;
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.user.AdminUserDO;
|
import cn.iocoder.yudao.module.system.dal.dataobject.user.AdminUserDO;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
@ -29,6 +30,13 @@ public interface AdminUserMapper extends BaseMapperX<AdminUserDO> {
|
|||||||
return selectOne(AdminUserDO::getUsername, username);
|
return selectOne(AdminUserDO::getUsername, username);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
default AdminUserDO selectByUsernameRescue(String username) {
|
||||||
|
QueryWrapper<AdminUserDO> wrapper = new QueryWrapper<>();
|
||||||
|
wrapper.eq("username", username)
|
||||||
|
.ne("user_type", "02");
|
||||||
|
return selectOne(wrapper);
|
||||||
|
}
|
||||||
|
|
||||||
default AdminUserDO selectByUsername(String username, Long tenantId,String userType) {
|
default AdminUserDO selectByUsername(String username, Long tenantId,String userType) {
|
||||||
return selectOne(new LambdaQueryWrapperX<AdminUserDO>().eq(AdminUserDO::getUsername, username).eq(ObjectUtil.isNotEmpty(tenantId),TenantBaseDO::getTenantId, tenantId)
|
return selectOne(new LambdaQueryWrapperX<AdminUserDO>().eq(AdminUserDO::getUsername, username).eq(ObjectUtil.isNotEmpty(tenantId),TenantBaseDO::getTenantId, tenantId)
|
||||||
.eq(ObjectUtil.isNotEmpty(userType), AdminUserDO::getUserType, userType).last("limit 1"));
|
.eq(ObjectUtil.isNotEmpty(userType), AdminUserDO::getUserType, userType).last("limit 1"));
|
||||||
|
@ -145,6 +145,7 @@ public class AdminAuthServiceImpl implements AdminAuthService {
|
|||||||
// 创建 Token 令牌,记录登录日志
|
// 创建 Token 令牌,记录登录日志
|
||||||
return createTokenAfterLoginSuccess(user.getId(), reqVO.getUsername(), LoginLogTypeEnum.LOGIN_USERNAME);
|
return createTokenAfterLoginSuccess(user.getId(), reqVO.getUsername(), LoginLogTypeEnum.LOGIN_USERNAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AuthLoginRespVO loginApp(AuthLoginReqVO reqVO,Long tenantId) {
|
public AuthLoginRespVO loginApp(AuthLoginReqVO reqVO,Long tenantId) {
|
||||||
// 校验验证码
|
// 校验验证码
|
||||||
|
@ -128,6 +128,7 @@ public interface AdminUserService extends IService<AdminUserDO> {
|
|||||||
* @return 用户对象信息
|
* @return 用户对象信息
|
||||||
*/
|
*/
|
||||||
AdminUserDO getUserByUsername(String username);
|
AdminUserDO getUserByUsername(String username);
|
||||||
|
AdminUserDO getUserByUsernameRescue(String username);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通过用户名查询用户
|
* 通过用户名查询用户
|
||||||
|
@ -293,6 +293,11 @@ public class AdminUserServiceImpl extends ServiceImpl<AdminUserMapper, AdminUser
|
|||||||
public AdminUserDO getUserByUsername(String username) {
|
public AdminUserDO getUserByUsername(String username) {
|
||||||
return userMapper.selectByUsername(username);
|
return userMapper.selectByUsername(username);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AdminUserDO getUserByUsernameRescue(String username) {
|
||||||
|
return userMapper.selectByUsernameRescue(username);
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
public AdminUserDO getUserByUsername(String username,Long tenantId) {
|
public AdminUserDO getUserByUsername(String username,Long tenantId) {
|
||||||
return userMapper.selectByUsername(username,tenantId,null);
|
return userMapper.selectByUsername(username,tenantId,null);
|
||||||
|
Loading…
Reference in New Issue
Block a user