diff --git a/src/main/java/com/xiang/ApplicationInit.java b/src/main/java/com/xiang/ApplicationInit.java index ca65b5b..3246791 100644 --- a/src/main/java/com/xiang/ApplicationInit.java +++ b/src/main/java/com/xiang/ApplicationInit.java @@ -54,7 +54,7 @@ public class ApplicationInit implements ApplicationRunner { continue; } ScheduleOpeningConfigDO scheduleOpeningConfigDO = new ScheduleOpeningConfigDO(); - scheduleOpeningConfigDO.setModule(scheduleEnum.getModeleCode()); + scheduleOpeningConfigDO.setModule(scheduleEnum.getModuleCode()); scheduleOpeningConfigDO.setBeanName(scheduleEnum.getTaskName()); scheduleOpeningConfigDO.setStatus(1); list.add(scheduleOpeningConfigDO); diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/constants/UrlConstant.java b/src/main/java/com/xiang/common/enums/JntyzxUrlConstant.java similarity index 93% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/constants/UrlConstant.java rename to src/main/java/com/xiang/common/enums/JntyzxUrlConstant.java index 227e072..1fd1023 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/constants/UrlConstant.java +++ b/src/main/java/com/xiang/common/enums/JntyzxUrlConstant.java @@ -1,10 +1,10 @@ -package com.xiang.service.module.jntyzx.miniapp.constants; +package com.xiang.common.enums; /** * @Author: xiang * @Date: 2025-12-15 13:46 */ -public class UrlConstant { +public class JntyzxUrlConstant { /** * 江南体育中心基础URL diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/constants/RedisKeyConstant.java b/src/main/java/com/xiang/common/enums/RedisKeyConstant.java similarity index 93% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/constants/RedisKeyConstant.java rename to src/main/java/com/xiang/common/enums/RedisKeyConstant.java index 8159f6c..6117a59 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/constants/RedisKeyConstant.java +++ b/src/main/java/com/xiang/common/enums/RedisKeyConstant.java @@ -1,6 +1,8 @@ -package com.xiang.service.module.jntyzx.miniapp.constants; +package com.xiang.common.enums; +import com.xiang.common.utils.DateUtils; + import java.time.LocalDate; /** diff --git a/src/main/java/com/xiang/common/enums/ScheduleEnums.java b/src/main/java/com/xiang/common/enums/ScheduleEnums.java index 3ba9daf..6ea4c02 100644 --- a/src/main/java/com/xiang/common/enums/ScheduleEnums.java +++ b/src/main/java/com/xiang/common/enums/ScheduleEnums.java @@ -31,9 +31,16 @@ public enum ScheduleEnums { ZLB_ORDER_CREATE_TASK(3, "zlb", "zlbOrderCreateTask"), ZLB_USER_CONFIG_TASK(3, "zlb", "zlbUserConfigTask"), + + JNTYZX_TOKEN_REFRESH_TASK(4, "jt-miniApp", "jntyzxTokenRefreshTask"), + JNTYZX_VENUE_INFO_PULL_TASK(4, "jt-miniApp", "jntyzxVenuePullTask"), + JNTYZX_ORDER_SUBSCRIBE_TASK(4, "jt-miniApp", "jntyzxOrderSubscribeTask"), + JNTYZX_VENUE_TODAY_SUBSCRIBE_TASK(4, "jt-miniApp", "jntyzxVenueTodaySubscribeTask"), + JNTYZX_VENUE_TOMORROW_PULL_TASK(4, "jt-miniApp", "jntyzxVenueTodayPullTask"), + JNTYZX_USER_INFO_CONFIG(4, "jt-miniApp", "jntyzxUserInfoConfigTask"), ; - private final Integer modeleCode; + private final Integer moduleCode; private final String module; private final String taskName; } diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IOrderCreateInfoManage.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IOrderCreateInfoManage.java similarity index 85% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IOrderCreateInfoManage.java rename to src/main/java/com/xiang/common/manage/jntyzx/miniapp/IOrderCreateInfoManage.java index 8757938..99315a7 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IOrderCreateInfoManage.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IOrderCreateInfoManage.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.miniapp.manage; +package com.xiang.common.manage.jntyzx.miniapp; import com.baomidou.mybatisplus.extension.service.IService; import com.xiang.common.pojo.jntyzx.miniapp.pojo.OrderInfoDO; diff --git a/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserInfoManage.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserInfoManage.java new file mode 100644 index 0000000..27ce953 --- /dev/null +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserInfoManage.java @@ -0,0 +1,12 @@ +package com.xiang.common.manage.jntyzx.miniapp; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserInfoDO; + +/** + * @Author: xiang + * @Date: 2026-05-09 10:17 + */ +public interface IUserInfoManage extends IService { + boolean delAll(); +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IUserRestrictionManage.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserRestrictionManage.java similarity index 86% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IUserRestrictionManage.java rename to src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserRestrictionManage.java index 77462a3..6f7f53d 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IUserRestrictionManage.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserRestrictionManage.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.miniapp.manage; +package com.xiang.common.manage.jntyzx.miniapp; import com.baomidou.mybatisplus.extension.service.IService; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserRestrictionInfo; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IUserTokenInfoManage.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserTokenInfoManage.java similarity index 90% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IUserTokenInfoManage.java rename to src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserTokenInfoManage.java index 24ee98a..6f702ce 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IUserTokenInfoManage.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IUserTokenInfoManage.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.miniapp.manage; +package com.xiang.common.manage.jntyzx.miniapp; import com.baomidou.mybatisplus.extension.service.IService; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IVenueInfoManage.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IVenueInfoManage.java similarity index 62% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IVenueInfoManage.java rename to src/main/java/com/xiang/common/manage/jntyzx/miniapp/IVenueInfoManage.java index 4cab8bf..7e3a517 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/IVenueInfoManage.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/IVenueInfoManage.java @@ -1,9 +1,7 @@ -package com.xiang.service.module.jntyzx.miniapp.manage; +package com.xiang.common.manage.jntyzx.miniapp; -import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.IService; import com.xiang.common.pojo.jntyzx.miniapp.pojo.VenueInfoDO; -import com.xiang.common.pojo.jntyzx.miniapp.req.VenueInfoQueryRequest; import java.time.LocalDate; import java.util.List; @@ -17,6 +15,4 @@ public interface IVenueInfoManage extends IService { List queryByDate(LocalDate date); List queryByType(LocalDate date, Integer type); - - Page page(VenueInfoQueryRequest request); } diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/OrderCreateInfoManageImpl.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/OrderCreateInfoManageImpl.java similarity index 85% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/OrderCreateInfoManageImpl.java rename to src/main/java/com/xiang/common/manage/jntyzx/miniapp/OrderCreateInfoManageImpl.java index a4ab30c..a3aee2c 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/OrderCreateInfoManageImpl.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/OrderCreateInfoManageImpl.java @@ -1,10 +1,10 @@ -package com.xiang.service.module.jntyzx.miniapp.manage; +package com.xiang.common.manage.jntyzx.miniapp; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.xiang.common.pojo.jntyzx.miniapp.pojo.OrderInfoDO; -import com.xiang.service.module.jntyzx.miniapp.mapper.JntyzxOrderCreateInfoMapper; +import com.xiang.common.mapper.JntyzxOrderCreateInfoMapper; import org.springframework.stereotype.Service; import java.util.List; diff --git a/src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserInfoManageImpl.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserInfoManageImpl.java new file mode 100644 index 0000000..db94e14 --- /dev/null +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserInfoManageImpl.java @@ -0,0 +1,18 @@ +package com.xiang.common.manage.jntyzx.miniapp; + +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.xiang.common.mapper.JntyzxUserInfoMapper; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserInfoDO; +import org.springframework.stereotype.Service; + +/** + * @Author: xiang + * @Date: 2026-05-09 10:17 + */ +@Service +public class UserInfoManageImpl extends ServiceImpl implements IUserInfoManage { + @Override + public boolean delAll() { + return baseMapper.delAll() > 0; + } +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/UserRestrictionManageImpl.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserRestrictionManageImpl.java similarity index 88% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/UserRestrictionManageImpl.java rename to src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserRestrictionManageImpl.java index e373f21..a5a0db7 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/UserRestrictionManageImpl.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserRestrictionManageImpl.java @@ -1,10 +1,10 @@ -package com.xiang.service.module.jntyzx.miniapp.manage; +package com.xiang.common.manage.jntyzx.miniapp; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserRestrictionInfo; -import com.xiang.service.module.jntyzx.miniapp.mapper.JntyzxUserRestrictionInfoMapper; +import com.xiang.common.mapper.JntyzxUserRestrictionInfoMapper; import org.springframework.stereotype.Service; import java.util.List; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/UserTokenInfoManageImpl.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserTokenInfoManageImpl.java similarity index 95% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/UserTokenInfoManageImpl.java rename to src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserTokenInfoManageImpl.java index c5eaaa6..d752e95 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/UserTokenInfoManageImpl.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/UserTokenInfoManageImpl.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.miniapp.manage; +package com.xiang.common.manage.jntyzx.miniapp; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.StringUtils; @@ -6,7 +6,7 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; import com.xiang.common.pojo.jntyzx.miniapp.req.UserQueryReq; -import com.xiang.service.module.jntyzx.miniapp.mapper.JntyzxUserTokenInfoMapper; +import com.xiang.common.mapper.JntyzxUserTokenInfoMapper; import org.springframework.stereotype.Service; import java.util.List; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/VenueInfoManageImpl.java b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/VenueInfoManageImpl.java similarity index 52% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/VenueInfoManageImpl.java rename to src/main/java/com/xiang/common/manage/jntyzx/miniapp/VenueInfoManageImpl.java index f0d6d1b..b949ad5 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/manage/VenueInfoManageImpl.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/miniapp/VenueInfoManageImpl.java @@ -1,13 +1,10 @@ -package com.xiang.service.module.jntyzx.miniapp.manage; +package com.xiang.common.manage.jntyzx.miniapp; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; -import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.xiang.common.pojo.jntyzx.miniapp.pojo.VenueInfoDO; -import com.xiang.common.pojo.jntyzx.miniapp.req.VenueInfoQueryRequest; -import com.xiang.service.module.jntyzx.miniapp.mapper.JntyzxVenueInfoMapper; -import org.apache.commons.lang3.StringUtils; +import com.xiang.common.mapper.JntyzxVenueInfoMapper; import org.springframework.stereotype.Service; import java.time.LocalDate; @@ -33,18 +30,4 @@ public class VenueInfoManageImpl extends ServiceImpl page(VenueInfoQueryRequest request) { - Page page = new Page<>(request.getCurrent(), request.getPageSize()); - LambdaQueryWrapper lqw = Wrappers.lambdaQuery(); - lqw.eq(VenueInfoDO::getDate, request.getDate()); - if (StringUtils.isNotBlank(request.getSj())) { - lqw.eq(VenueInfoDO::getSjName, request.getSj()); - } - if (StringUtils.isNotBlank(request.getPlaceName())) { - lqw.like(VenueInfoDO::getPlaceName, request.getPlaceName()); - } - return baseMapper.selectPage(page, lqw); - } } diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbSiteInfoService.java b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbSiteInfoService.java similarity index 85% rename from src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbSiteInfoService.java rename to src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbSiteInfoService.java index e6d4844..9f10a0b 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbSiteInfoService.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbSiteInfoService.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.zlb.service; +package com.xiang.common.manage.jntyzx.zlb; import com.baomidou.mybatisplus.extension.service.IService; import com.xiang.common.pojo.jntyzx.zlb.ZlbSiteInfo; diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbSiteInfoServiceImpl.java b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbSiteInfoServiceImpl.java similarity index 90% rename from src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbSiteInfoServiceImpl.java rename to src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbSiteInfoServiceImpl.java index a4cdbf4..f7d394c 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbSiteInfoServiceImpl.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbSiteInfoServiceImpl.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.zlb.service; +package com.xiang.common.manage.jntyzx.zlb; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.xiang.common.mapper.ZlbSiteInfoMapper; diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbTokenInfoService.java b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbTokenInfoService.java similarity index 88% rename from src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbTokenInfoService.java rename to src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbTokenInfoService.java index 50ccc5d..9cd6008 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbTokenInfoService.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbTokenInfoService.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.zlb.service; +package com.xiang.common.manage.jntyzx.zlb; import com.baomidou.mybatisplus.extension.service.IService; import com.xiang.common.pojo.jntyzx.zlb.ZlbTokenInfo; diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbTokenInfoServiceImpl.java b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbTokenInfoServiceImpl.java similarity index 95% rename from src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbTokenInfoServiceImpl.java rename to src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbTokenInfoServiceImpl.java index 6cf6826..5d23605 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbTokenInfoServiceImpl.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbTokenInfoServiceImpl.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.zlb.service; +package com.xiang.common.manage.jntyzx.zlb; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbUserInfoService.java b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbUserInfoService.java similarity index 88% rename from src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbUserInfoService.java rename to src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbUserInfoService.java index fc2b192..557faa6 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbUserInfoService.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbUserInfoService.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.zlb.service; +package com.xiang.common.manage.jntyzx.zlb; import com.baomidou.mybatisplus.extension.service.IService; import com.xiang.common.pojo.jntyzx.zlb.ZlbUserInfo; diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbUserInfoServiceImpl.java b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbUserInfoServiceImpl.java similarity index 91% rename from src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbUserInfoServiceImpl.java rename to src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbUserInfoServiceImpl.java index 8420323..04fd5e6 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbUserInfoServiceImpl.java +++ b/src/main/java/com/xiang/common/manage/jntyzx/zlb/ZlbUserInfoServiceImpl.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.zlb.service; +package com.xiang.common.manage.jntyzx.zlb; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.xiang.common.mapper.ZlbUserInfoMapper; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxOrderCreateInfoMapper.java b/src/main/java/com/xiang/common/mapper/JntyzxOrderCreateInfoMapper.java similarity index 86% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxOrderCreateInfoMapper.java rename to src/main/java/com/xiang/common/mapper/JntyzxOrderCreateInfoMapper.java index c5c9aad..0bfaa6f 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxOrderCreateInfoMapper.java +++ b/src/main/java/com/xiang/common/mapper/JntyzxOrderCreateInfoMapper.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.miniapp.mapper; +package com.xiang.common.mapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.xiang.common.pojo.jntyzx.miniapp.pojo.OrderInfoDO; diff --git a/src/main/java/com/xiang/common/mapper/JntyzxUserInfoMapper.java b/src/main/java/com/xiang/common/mapper/JntyzxUserInfoMapper.java new file mode 100644 index 0000000..cfe1b00 --- /dev/null +++ b/src/main/java/com/xiang/common/mapper/JntyzxUserInfoMapper.java @@ -0,0 +1,20 @@ +package com.xiang.common.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserInfoDO; +import org.apache.ibatis.annotations.Delete; +import org.apache.ibatis.annotations.Mapper; +import org.springframework.stereotype.Repository; + +/** + * @Author: xiang + * @Date: 2026-05-09 10:16 + */ +@Mapper +@Repository +public interface JntyzxUserInfoMapper extends BaseMapper { + + @Delete("delete from jntyzx_user_info where 1=1") + int delAll(); + +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxUserRestrictionInfoMapper.java b/src/main/java/com/xiang/common/mapper/JntyzxUserRestrictionInfoMapper.java similarity index 85% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxUserRestrictionInfoMapper.java rename to src/main/java/com/xiang/common/mapper/JntyzxUserRestrictionInfoMapper.java index f492211..bde072c 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxUserRestrictionInfoMapper.java +++ b/src/main/java/com/xiang/common/mapper/JntyzxUserRestrictionInfoMapper.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.miniapp.mapper; +package com.xiang.common.mapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserRestrictionInfo; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxUserTokenInfoMapper.java b/src/main/java/com/xiang/common/mapper/JntyzxUserTokenInfoMapper.java similarity index 87% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxUserTokenInfoMapper.java rename to src/main/java/com/xiang/common/mapper/JntyzxUserTokenInfoMapper.java index 5b53abb..447f82e 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxUserTokenInfoMapper.java +++ b/src/main/java/com/xiang/common/mapper/JntyzxUserTokenInfoMapper.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.miniapp.mapper; +package com.xiang.common.mapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxVenueInfoMapper.java b/src/main/java/com/xiang/common/mapper/JntyzxVenueInfoMapper.java similarity index 86% rename from src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxVenueInfoMapper.java rename to src/main/java/com/xiang/common/mapper/JntyzxVenueInfoMapper.java index 2ba47bf..c16fa62 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/mapper/JntyzxVenueInfoMapper.java +++ b/src/main/java/com/xiang/common/mapper/JntyzxVenueInfoMapper.java @@ -1,4 +1,4 @@ -package com.xiang.service.module.jntyzx.miniapp.mapper; +package com.xiang.common.mapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.xiang.common.pojo.jntyzx.miniapp.pojo.VenueInfoDO; diff --git a/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/pojo/UserInfoDO.java b/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/pojo/UserInfoDO.java new file mode 100644 index 0000000..0036631 --- /dev/null +++ b/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/pojo/UserInfoDO.java @@ -0,0 +1,53 @@ +package com.xiang.common.pojo.jntyzx.miniapp.pojo; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; +import lombok.Data; + +/** + * @Author: xiang + * @Date: 2026-05-09 09:54 + */ +@Data +@TableName("jntyzx_user_info") +public class UserInfoDO { + /** + * + */ + @TableId(type = IdType.AUTO) + private Integer id; + + private Integer loginInfoId; + + /** + * 名称 + */ + private String name; + + /** + * 星期几 + */ + private String week; + + /** + * 分配的任务参数 + */ + private String type; + + /** + * 场地信息 + */ + private String placeName; + + /** + * 时间id111 + */ + private String siteTimeName; + + /** + * 是否开抢0-抢,1-不抢 + */ + private Integer isBook; + +} diff --git a/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/req/SubscribeRequest.java b/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/req/SubscribeRequest.java index a048087..bd3c51a 100644 --- a/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/req/SubscribeRequest.java +++ b/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/req/SubscribeRequest.java @@ -16,7 +16,7 @@ import java.util.List; @NoArgsConstructor public class SubscribeRequest { private JSONObject jsonObject; - private List subscribeVos; + private List subscribeVos; private String bookTime; private Integer paymentMethod; private String svCiphertext; diff --git a/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/resp/query/QueryVenueResponse.java b/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/resp/query/QueryVenueResponse.java index 9a8cae5..3d9dec0 100644 --- a/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/resp/query/QueryVenueResponse.java +++ b/src/main/java/com/xiang/common/pojo/jntyzx/miniapp/resp/query/QueryVenueResponse.java @@ -1,3 +1,4 @@ +package com.xiang.common.pojo.jntyzx.miniapp.resp.query; import lombok.Data; diff --git a/src/main/java/com/xiang/common/utils/DateUtils.java b/src/main/java/com/xiang/common/utils/DateUtils.java index a00d5ea..b040f36 100644 --- a/src/main/java/com/xiang/common/utils/DateUtils.java +++ b/src/main/java/com/xiang/common/utils/DateUtils.java @@ -26,75 +26,20 @@ import java.util.concurrent.TimeUnit; */ public class DateUtils { - private static final String defaultDateFormatter = "yyyy-MM-dd"; - private static final String defaultDateTimeFormatter = "yyyy-MM-dd HH:mm:ss"; + private static final Logger logger = LoggerFactory.getLogger(DateUtils.class); - - /** - * 构造函数. - */ - public void DateUtil() { - throw new RuntimeException("this is a util class,can not instance!"); - } - - /** - * 添加字段注释. - */ public static final String ENUM_FORMAT = "yyyy-MM-dd HH:mm:ss"; - /** - * 添加字段注释. - */ public static final String ASCM_FORMAT = "yyyy-MM-dd'T'HH:mm:ss'Z'"; - - /** - * 添加字段注释. - */ public static final String ENUM_FORMAT_YMD = "yyyy-MM-dd"; public static final String ENUM_FORMAT_YMD_1 = "yyyyMMdd"; - - /** - * 添加字段注释. - */ public static final String ENUM_FORMAT_YMDS = "yyyy-MM-dd HH:mm:ss.S"; - - /** - * 添加字段注释. - */ public static final String ENUM_FORMAT_SLASH = "yyyy/MM/dd HH:mm:ss"; - - /** - * 添加字段注释. - */ public static final String ENUM_FORMAT_YMDS_SLASH = "yyyy/MM/dd HH:mm:ss.S"; - - /** - * 添加字段注释. - */ public static final String LEVEL_DAY = "day"; // 粒度级别 - - /** - * 添加字段注释. - */ public static final String LEVEL_HOUR = "hour"; - - /** - * 添加字段注释. - */ public static final String LEVEL_MINUTE = "minute"; - - /** - * 添加字段注释. - */ public static final String LEVEL_SECOND = "second"; - - /** - * 日期特殊字符对应. - */ private static Map mapSign = new HashMap<>(); - - /** - * 使用ThreadLocal保证SimpleDateFormat线程安全. - */ private static ThreadLocal> threadLocalDateFormat = new ThreadLocal<>(); /** @@ -141,6 +86,11 @@ public class DateUtils { return convertToChinese(dayOfWeek); } + public static String getWeekDay(LocalDate date) { + DayOfWeek dayOfWeek = date.getDayOfWeek(); + return convertToChinese(dayOfWeek); + } + private static String convertToChinese(DayOfWeek dayOfWeek) { switch (dayOfWeek) { case MONDAY: @@ -658,7 +608,7 @@ public class DateUtils { boolean inAfternoon = now.isAfter(LocalTime.of(12, 59)) && now.isBefore(LocalTime.of(15, 1)); return !inAfternoon && !inMorning ? true : false; } else { - log.info("当前时间为:{}", LocalDateTime.now()); + logger.info("当前时间为:{}", LocalDateTime.now()); return true; } } diff --git a/src/main/java/com/xiang/common/utils/JsonUtils.java b/src/main/java/com/xiang/common/utils/JsonUtils.java new file mode 100644 index 0000000..19814d2 --- /dev/null +++ b/src/main/java/com/xiang/common/utils/JsonUtils.java @@ -0,0 +1,18 @@ +package com.xiang.common.utils; + +import com.alibaba.fastjson.JSON; +import com.alibaba.fastjson.serializer.SerializerFeature; + +/** + * @Author: xiang + * @Date: 2025-07-25 15:58 + */ +public class JsonUtils { + public static String toJsonString(Object obj) { + return JSON.toJSONString(obj, SerializerFeature.WriteMapNullValue); + } + + public static T parse(String json, Class clazz) { + return JSON.parseObject(json, clazz); + } +} diff --git a/src/main/java/com/xiang/service/module/domain/schedule/DomainDynamicAnalysisTask.java b/src/main/java/com/xiang/service/module/domain/schedule/DomainDynamicAnalysisTask.java index b41777f..648a0b3 100644 --- a/src/main/java/com/xiang/service/module/domain/schedule/DomainDynamicAnalysisTask.java +++ b/src/main/java/com/xiang/service/module/domain/schedule/DomainDynamicAnalysisTask.java @@ -23,7 +23,7 @@ public class DomainDynamicAnalysisTask extends BaseScheduleTaskTemplate { @Override protected Integer getModule() { - return ScheduleEnums.DOMAIN_DYNAMIC_ANALYSIS_TASK.getModeleCode(); + return ScheduleEnums.DOMAIN_DYNAMIC_ANALYSIS_TASK.getModuleCode(); } @Override diff --git a/src/main/java/com/xiang/service/module/glados/schedule/GladosCheckInTask.java b/src/main/java/com/xiang/service/module/glados/schedule/GladosCheckInTask.java index 60be5e7..9be0cf2 100644 --- a/src/main/java/com/xiang/service/module/glados/schedule/GladosCheckInTask.java +++ b/src/main/java/com/xiang/service/module/glados/schedule/GladosCheckInTask.java @@ -31,7 +31,7 @@ public class GladosCheckInTask extends BaseScheduleTaskTemplate { @Override protected Integer getModule() { - return ScheduleEnums.GLADOS_CHECK_IN_TASK.getModeleCode(); + return ScheduleEnums.GLADOS_CHECK_IN_TASK.getModuleCode(); } @Override diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/converts/UserConverter.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/converts/UserConverter.java deleted file mode 100644 index 4ff851e..0000000 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/converts/UserConverter.java +++ /dev/null @@ -1,32 +0,0 @@ -package com.xiang.service.module.jntyzx.miniapp.converts; - -import com.xiang.common.pojo.jntyzx.miniapp.resp.JtUserVo; -import com.xiang.service.module.jntyzx.miniapp.entity.pojo.UserTokenInfoDO; -import org.mapstruct.Mapper; -import org.mapstruct.Mapping; -import org.mapstruct.Named; -import org.mapstruct.factory.Mappers; - -import java.util.List; -import java.util.Objects; - -@Mapper(componentModel = "spring") -public interface UserConverter { - - UserConverter INSTANCE = Mappers.getMapper(UserConverter.class); - @Mapping(source = "id", target = "userId") - @Mapping(source = "isOrder", target = "isOrder", qualifiedByName = "isOrder") - @Mapping(source = "isRestriction", target = "isRestriction", qualifiedByName = "isRestrict") - JtUserVo convert(UserTokenInfoDO userTokenInfoDO); - List convert(List userTokenInfoDOs); - - @Named("isOrder") - default Boolean isOrder(Integer value) { - return Objects.nonNull(value) && Objects.equals(value, 1); - } - - @Named("isRestrict") - default Boolean isRestrict(Integer value) { - return Objects.nonNull(value) && Objects.equals(value, 0); - } -} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/converts/VenueInfoConverter.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/converts/VenueInfoConverter.java deleted file mode 100644 index 3f60aab..0000000 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/converts/VenueInfoConverter.java +++ /dev/null @@ -1,16 +0,0 @@ -package com.xiang.service.module.jntyzx.miniapp.converts; - -import com.baomidou.mybatisplus.extension.plugins.pagination.Page; -import com.xiang.common.pojo.jntyzx.miniapp.resp.VenueInfoQueryResp; -import com.xiang.service.module.jntyzx.miniapp.entity.pojo.VenueInfoDO; -import org.mapstruct.Mapper; - -/** - * @Author: xiang - * @Date: 2026-04-09 09:54 - */ -@Mapper(componentModel = "spring") -public interface VenueInfoConverter { - - Page toPage(Page page); -} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JntyzxMiniappScheduleConfig.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JntyzxMiniappScheduleConfig.java new file mode 100644 index 0000000..aff3a11 --- /dev/null +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JntyzxMiniappScheduleConfig.java @@ -0,0 +1,53 @@ +package com.xiang.service.module.jntyzx.miniapp.schedule; + +import lombok.RequiredArgsConstructor; +import org.springframework.scheduling.annotation.Scheduled; +import org.springframework.stereotype.Component; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +/** + * @Author: xiang + * @Date: 2026-05-09 08:56 + */ +@Component +@RequiredArgsConstructor +@RestController +public class JntyzxMiniappScheduleConfig { + + private final JtTokenRefreshTask jtTokenRefreshTask; + private final JtVenuePullTask jtVenuePullTask; + private final JtVenueSubscribeTask jtVenueSubscribeTask; + private final JtVenueTomorrowPullTask jtVenueTomorrowPullTask; + + + @Scheduled(cron = "0 20,50 * * * ?") + @GetMapping("/jtTokenRefreshTask") + public void jtTokenRefreshTask() { + jtTokenRefreshTask.run(); + } + + @Scheduled(cron = "0 0/1 10-18 * * ?") + @GetMapping("/jtVenuePullTask") + public void jtVenuePullTask() { + jtVenuePullTask.run(); + } + + @Scheduled(cron = "0 30 8 * * ?") + @GetMapping("/jtVenueTomorrowPullTask") + public void jtVenueTomorrowPullTask() { + jtVenueTomorrowPullTask.run(); + } + + @Scheduled(cron = "0 40 8 * * ?") + @GetMapping("/jtUserInfoConfig") + public void jtUserInfoConfig() { + + } + + @Scheduled(cron = "5 0 9 * * ?") + @GetMapping("/jtVenueSubscribeTask") + public void jtVenueSubscribeTask() { + jtVenueSubscribeTask.run(); + } +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JntyzxUserInfoConfigTask.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JntyzxUserInfoConfigTask.java new file mode 100644 index 0000000..9f6dd70 --- /dev/null +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JntyzxUserInfoConfigTask.java @@ -0,0 +1,116 @@ +package com.xiang.service.module.jntyzx.miniapp.schedule; + +import com.google.common.collect.Lists; +import com.xiang.common.enums.ScheduleEnums; +import com.xiang.common.factory.JntyzxDingTalkFactory; +import com.xiang.common.factory.schedule.BaseScheduleTaskTemplate; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserInfoDO; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.VenueInfoDO; +import com.xiang.common.pojo.schedule.TaskResult; +import com.xiang.common.service.IScheduleOpeningConfigService; +import com.xiang.common.service.IScheduleRunLogService; +import com.xiang.common.utils.DateUtils; +import com.xiang.service.module.jntyzx.miniapp.service.IUserInfoService; +import com.xiang.service.module.jntyzx.miniapp.service.IUserTokenInfoService; +import com.xiang.service.module.jntyzx.miniapp.service.IVenueService; +import com.xiang.service.module.jntyzx.miniapp.utils.VenueInfoUtils; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.CollectionUtils; +import org.springframework.stereotype.Component; + +import java.util.List; + +/** + * @Author: xiang + * @Date: 2026-05-09 09:58 + */ +@Component +@Slf4j +public class JntyzxUserInfoConfigTask extends BaseScheduleTaskTemplate { + + private final IUserTokenInfoService userTokenInfoService; + private final IVenueService venueService; + private final IUserInfoService userInfoService; + private final JntyzxDingTalkFactory jntyzxDingTalkFactory; + + public JntyzxUserInfoConfigTask(IScheduleOpeningConfigService scheduleOpeningConfigService, + IScheduleRunLogService scheduleRunLogService, + IUserTokenInfoService userTokenInfoService, + IVenueService venueService, + IUserInfoService userInfoService, + JntyzxDingTalkFactory jntyzxDingTalkFactory) { + super(scheduleOpeningConfigService, scheduleRunLogService); + this.userTokenInfoService = userTokenInfoService; + this.venueService = venueService; + this.userInfoService = userInfoService; + this.jntyzxDingTalkFactory = jntyzxDingTalkFactory; + } + + @Override + protected String getTaskName() { + return ScheduleEnums.JNTYZX_USER_INFO_CONFIG.getTaskName(); + } + + @Override + protected Integer getModule() { + return ScheduleEnums.JNTYZX_USER_INFO_CONFIG.getModuleCode(); + } + + @Override + protected String getModuleName() { + return ScheduleEnums.JNTYZX_USER_INFO_CONFIG.getModule(); + } + + @Override + protected TaskResult doExecute(Object validatedParams) throws Exception { + TaskResult taskResult = new TaskResult(); + taskResult.setSuccess(false); + List venueInfoDOS = venueService.queryCanBuyVenue(); + if (CollectionUtils.isEmpty(venueInfoDOS)) { + taskResult.setSummary("无可用场地"); + return taskResult; + } + venueInfoDOS = venueInfoDOS.stream().filter(VenueInfoUtils::get628VenueInfo).toList(); + if (CollectionUtils.isEmpty(venueInfoDOS)) { + taskResult.setSummary("无可用场地"); + return taskResult; + } + + List users = userTokenInfoService.getCanOrderUser(); + if (CollectionUtils.isEmpty(users)) { + taskResult.setSummary("无可用用户"); + return taskResult; + } + + List list = Lists.newArrayList(); + int i = 0; + for (UserTokenInfoDO user : users) { + VenueInfoDO venueInfoDO = venueInfoDOS.get(i); + UserInfoDO userInfoDO = new UserInfoDO(); + userInfoDO.setName(user.getName()); + userInfoDO.setWeek(DateUtils.getWeekDay(venueInfoDO.getDate())); + userInfoDO.setType("1"); + userInfoDO.setPlaceName(venueInfoDO.getPlaceName()); + userInfoDO.setSiteTimeName(venueInfoDO.getSjName().split("-")[0]); + userInfoDO.setIsBook(0); + list.add(userInfoDO); + i++; + if (i == venueInfoDOS.size()) { + i = 0; + } + } + + if (CollectionUtils.isNotEmpty(list)) { + userInfoService.batchSave(list); + StringBuilder stringBuilder = new StringBuilder(); + for (UserInfoDO user : list) { + stringBuilder.append(user.getName()).append("配置预约:").append(user.getPlaceName()).append("\n"); + } + jntyzxDingTalkFactory.sendMsg(stringBuilder.toString()); + taskResult.setSuccess(Boolean.TRUE); + taskResult.setSummary(stringBuilder.toString()); + } + return taskResult; + } +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtTokenRefreshTask.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtTokenRefreshTask.java new file mode 100644 index 0000000..db89af1 --- /dev/null +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtTokenRefreshTask.java @@ -0,0 +1,57 @@ +package com.xiang.service.module.jntyzx.miniapp.schedule; + +import com.xiang.common.enums.ScheduleEnums; +import com.xiang.common.factory.schedule.BaseScheduleTaskTemplate; +import com.xiang.common.pojo.schedule.TaskResult; +import com.xiang.common.service.IScheduleOpeningConfigService; +import com.xiang.common.service.IScheduleRunLogService; +import com.xiang.service.module.jntyzx.miniapp.service.IUserTokenInfoService; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Component; +import org.springframework.web.bind.annotation.RestController; + +/** + * @Author: xiang + * @Date: 2026-01-15 17:29 + */ +@Slf4j +@Component +@RestController +public class JtTokenRefreshTask extends BaseScheduleTaskTemplate { + + private final IUserTokenInfoService userTokenInfoService; + + public JtTokenRefreshTask(IScheduleOpeningConfigService scheduleOpeningConfigService, + IScheduleRunLogService scheduleRunLogService, + IUserTokenInfoService userTokenInfoService) { + super(scheduleOpeningConfigService, scheduleRunLogService); + this.userTokenInfoService = userTokenInfoService; + } + + @Override + protected String getTaskName() { + return ScheduleEnums.JNTYZX_TOKEN_REFRESH_TASK.getTaskName(); + } + + @Override + protected Integer getModule() { + return ScheduleEnums.JNTYZX_TOKEN_REFRESH_TASK.getModuleCode(); + } + + @Override + protected String getModuleName() { + return ScheduleEnums.JNTYZX_TOKEN_REFRESH_TASK.getModule(); + } + + @Override + protected TaskResult doExecute(Object validatedParams) throws Exception { + TaskResult taskResult = new TaskResult(); + + log.info("【Token】江南体育中心token续期定时任务启动!!!time:{}", System.currentTimeMillis()); + userTokenInfoService.flushToken(); + + taskResult.setSuccess(true); + taskResult.setSummary("江体小程序token刷新成功"); + return taskResult; + } +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenuePullTask.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenuePullTask.java new file mode 100644 index 0000000..ecde99a --- /dev/null +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenuePullTask.java @@ -0,0 +1,144 @@ +package com.xiang.service.module.jntyzx.miniapp.schedule; + +import com.google.common.collect.Maps; +import com.xiang.common.enums.RedisKeyConstant; +import com.xiang.common.enums.ScheduleEnums; +import com.xiang.common.factory.schedule.BaseScheduleTaskTemplate; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; +import com.xiang.common.pojo.jntyzx.miniapp.resp.query.SitePositionList; +import com.xiang.common.pojo.schedule.TaskResult; +import com.xiang.common.service.IScheduleOpeningConfigService; +import com.xiang.common.service.IScheduleRunLogService; +import com.xiang.common.utils.DateUtils; +import com.xiang.service.module.jntyzx.miniapp.service.IJntyzxHttpService; +import com.xiang.service.module.jntyzx.miniapp.service.IUserTokenInfoService; +import com.xiang.service.module.jntyzx.miniapp.service.IVenueService; +import com.xiang.service.module.jntyzx.miniapp.utils.MsgSendUtils; +import com.xiang.service.module.jntyzx.miniapp.utils.VenueInfoUtils; +import com.xiang.service.module.jntyzx.miniapp.utils.WeekendUtils; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.CollectionUtils; +import org.apache.commons.lang3.StringUtils; +import org.springframework.stereotype.Component; +import org.springframework.web.bind.annotation.RestController; + +import java.time.LocalDate; +import java.time.LocalDateTime; +import java.util.List; +import java.util.Map; +import java.util.Objects; + +/** + * 每日9:00-19:00场地更新信息查询 + */ +@Component +@Slf4j +@RestController +public class JtVenuePullTask extends BaseScheduleTaskTemplate { + + private final IUserTokenInfoService userTokenInfoService; + private final IJntyzxHttpService jntyzxHttpService; + private final IVenueService venueService; + private final MsgSendUtils msgSendUtils; + + public JtVenuePullTask(IScheduleOpeningConfigService scheduleOpeningConfigService, + IScheduleRunLogService scheduleRunLogService, + IUserTokenInfoService userTokenInfoService, + IJntyzxHttpService jntyzxHttpService, + IVenueService venueService, + MsgSendUtils msgSendUtils) { + super(scheduleOpeningConfigService, scheduleRunLogService); + this.userTokenInfoService = userTokenInfoService; + this.jntyzxHttpService = jntyzxHttpService; + this.venueService = venueService; + this.msgSendUtils = msgSendUtils; + } + + private List handleMsgSendList(List sitePositionLists, int dayOfWeek) { + // 过滤出来8-10的未订购的场地信息 + sitePositionLists = sitePositionLists.stream() + .filter(VenueInfoUtils::get8210VenueInfo) + .filter(item -> StringUtils.equals(item.getContacts(), "0")).toList(); + // 周六周日过滤小馆,不查询当天小馆信息 + if (dayOfWeek == 6 || dayOfWeek == 7) { + return sitePositionLists.stream() + .filter(item -> !item.getPlaceName().contains("小馆")) + .toList(); + } + Map mapByName = Maps.newLinkedHashMap(); + for (SitePositionList sitePositionList : sitePositionLists) { + if (!mapByName.containsKey(sitePositionList.getPlaceName())) { + mapByName.put(sitePositionList.getPlaceName(), sitePositionList); + } + } + return mapByName.values().stream().toList(); + } + + @Override + protected String getTaskName() { + return ScheduleEnums.JNTYZX_VENUE_INFO_PULL_TASK.getTaskName(); + } + + @Override + protected Integer getModule() { + return ScheduleEnums.JNTYZX_VENUE_INFO_PULL_TASK.getModuleCode(); + } + + @Override + protected String getModuleName() { + return ScheduleEnums.JNTYZX_VENUE_INFO_PULL_TASK.getModule(); + } + + @Override + protected TaskResult doExecute(Object validatedParams) throws Exception { + + TaskResult taskResult = new TaskResult(); + taskResult.setSuccess(false); + log.info("【Venue】江体小程序场地数据拉取定时任务启动!!!time:{}", System.currentTimeMillis()); + List availableUser = userTokenInfoService.getAvailableUser(); + if (CollectionUtils.isEmpty(availableUser)) { + log.info("当前无可用用户查询场地信息!"); + taskResult.setSuccess(true); + taskResult.setSummary("当前无可用用户查询场地信息!"); + return taskResult; + } + String token; + LocalDateTime now = LocalDateTime.now(); + int dayOfWeek = now.getDayOfWeek().getValue(); + + for (UserTokenInfoDO userTokenInfoDO : availableUser) { + if (Objects.isNull(userTokenInfoDO)) { + continue; + } + token = userTokenInfoDO.getToken(); + if (StringUtils.isBlank(token)) { + continue; + } + List sitePositionLists = jntyzxHttpService.queryAvailable(WeekendUtils.isWeekend(), token); + if (CollectionUtils.isEmpty(sitePositionLists)) { + continue; + } + venueService.saveOrUpdateTodayVenueInfo(sitePositionLists); + + sitePositionLists = handleMsgSendList(sitePositionLists, dayOfWeek); + if (CollectionUtils.isEmpty(sitePositionLists)) { + taskResult.setSuccess(true); + taskResult.setSummary("当前无场地信息!"); + return taskResult; + } + + StringBuffer msg = new StringBuffer( + "查询到20:00-22:00空闲场地信息=====>\n时间:" + DateUtils.getDateFromDate(LocalDate.now()) + "\n"); + sitePositionLists.forEach(item -> { + msg.append(item.getPlaceName()).append("\n"); + }); + + String key = RedisKeyConstant.JNTYZX_VENUE_MSG_SEND_KEY + RedisKeyConstant.getDate(); + msgSendUtils.sendMsgRestrict1Hours(key, msg.toString()); + taskResult.setSuccess(true); + taskResult.setSummary("查询场地信息成功!时间:" + now); + return taskResult; + } + return taskResult; + } +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenueSubscribeTask.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenueSubscribeTask.java new file mode 100644 index 0000000..e1c0989 --- /dev/null +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenueSubscribeTask.java @@ -0,0 +1,127 @@ +package com.xiang.service.module.jntyzx.miniapp.schedule; + +import com.alibaba.fastjson.JSON; +import com.xiang.common.enums.RedisKeyConstant; +import com.xiang.common.enums.ScheduleEnums; +import com.xiang.common.factory.JntyzxDingTalkFactory; +import com.xiang.common.factory.schedule.BaseScheduleTaskTemplate; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.VenueInfoDO; +import com.xiang.common.pojo.schedule.TaskResult; +import com.xiang.common.service.IScheduleOpeningConfigService; +import com.xiang.common.service.IScheduleRunLogService; +import com.xiang.common.utils.RedisService; +import com.xiang.service.module.jntyzx.miniapp.service.IJtOrderService; +import com.xiang.service.module.jntyzx.miniapp.service.IUserTokenInfoService; +import com.xiang.service.module.jntyzx.miniapp.service.IVenueService; +import com.xiang.service.module.jntyzx.miniapp.utils.VenueInfoUtils; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.CollectionUtils; +import org.apache.commons.collections4.MapUtils; +import org.apache.commons.lang3.StringUtils; +import org.springframework.stereotype.Component; +import org.springframework.web.bind.annotation.RestController; + +import java.util.Comparator; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +@Slf4j +@Component +@RestController +public class JtVenueSubscribeTask extends BaseScheduleTaskTemplate { + + private final IUserTokenInfoService userTokenInfoService; + private final IJtOrderService jtOrderService; + private final IVenueService venueService; + private final JntyzxDingTalkFactory jtDingTalkFactory; + private final RedisService redisService; + + public JtVenueSubscribeTask(IScheduleOpeningConfigService scheduleOpeningConfigService, + IScheduleRunLogService scheduleRunLogService, + IUserTokenInfoService userTokenInfoService, + IJtOrderService jtOrderService, + IVenueService venueService, + JntyzxDingTalkFactory jtDingTalkFactory, + RedisService redisService) { + super(scheduleOpeningConfigService, scheduleRunLogService); + this.userTokenInfoService = userTokenInfoService; + this.jtOrderService = jtOrderService; + this.venueService = venueService; + this.jtDingTalkFactory = jtDingTalkFactory; + this.redisService = redisService; + } + + @Override + protected String getTaskName() { + return ScheduleEnums.JNTYZX_ORDER_SUBSCRIBE_TASK.getTaskName(); + } + + @Override + protected Integer getModule() { + return ScheduleEnums.JNTYZX_ORDER_SUBSCRIBE_TASK.getModuleCode(); + } + + @Override + protected String getModuleName() { + return ScheduleEnums.JNTYZX_ORDER_SUBSCRIBE_TASK.getModule(); + } + + @Override + protected TaskResult doExecute(Object validatedParams) throws Exception { + TaskResult taskResult = new TaskResult(); + taskResult.setSuccess(false); + + log.info("【Subscribe】 江体场地预定定时任务启动!!! time:{}", System.currentTimeMillis()); + List users = userTokenInfoService.getCanOrderUser(); + if (CollectionUtils.isEmpty(users)) { + log.info("暂无可下单用户, time:{}", System.currentTimeMillis()); + jtDingTalkFactory.sendMsg("暂无可下单用户, time:" + System.currentTimeMillis()); + taskResult.setSummary("无可下单用户"); + return taskResult; + } + List venueInfoDOS = venueService.queryTomorrowCanBuyVenue(); + Map> venueInfoMap = venueInfoDOS.stream() + .filter(VenueInfoUtils::get8210VenueInfo) + .filter(item -> !StringUtils.contains(item.getPlaceName(), "小馆")) + .collect(Collectors.groupingByConcurrent(VenueInfoDO::getPlaceName)); + if (MapUtils.isEmpty(venueInfoMap)) { + log.info("暂无可下单场地,time:{}", System.currentTimeMillis()); + taskResult.setSummary("无下单场地"); + return taskResult; + } + + users.parallelStream().forEach(user -> { + try { + List placeNameList = venueInfoMap.keySet().stream().sorted(Comparator.comparing(VenueInfoUtils::sortVenueInfo)).toList(); + log.info("场地排序后的集合:{}", JSON.toJSONString(placeNameList)); + for (String placeName : placeNameList) { + List venueInfoDOList = venueInfoMap.get(placeName); + for (int i = 0; i < 10; i++) { + String valid = (String) redisService.get(RedisKeyConstant.getVenueSubscribeKey(placeName)); + if (StringUtils.isNotBlank(valid)) { + break; + } + boolean order = jtOrderService.createOrder(venueInfoDOList, user); + if (order) { + return; + } + try { + Thread.sleep(1250); + } catch (InterruptedException e) { + log.error("睡眠失败~~~"); + } + } + } + } catch (Exception e) { + // 关键点:异常只影响当前 user + log.error("createOrder 异常,user={}", user.getId(), e); + return; // 结束这个 user,不影响其他 user + } + }); + taskResult.setSuccess(true); + taskResult.setSummary("下单执行成功!"); + return taskResult; + } +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenueTomorrowPullTask.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenueTomorrowPullTask.java new file mode 100644 index 0000000..be08f35 --- /dev/null +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/schedule/JtVenueTomorrowPullTask.java @@ -0,0 +1,121 @@ +package com.xiang.service.module.jntyzx.miniapp.schedule; + + +import com.google.common.collect.Maps; +import com.xiang.common.enums.ScheduleEnums; +import com.xiang.common.factory.JntyzxDingTalkFactory; +import com.xiang.common.factory.schedule.BaseScheduleTaskTemplate; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; +import com.xiang.common.pojo.jntyzx.miniapp.resp.JntyzxResponse; +import com.xiang.common.pojo.jntyzx.miniapp.resp.query.SitePositionList; +import com.xiang.common.pojo.schedule.TaskResult; +import com.xiang.common.service.IScheduleOpeningConfigService; +import com.xiang.common.service.IScheduleRunLogService; +import com.xiang.common.utils.DateUtils; +import com.xiang.service.module.jntyzx.miniapp.service.IJntyzxHttpService; +import com.xiang.service.module.jntyzx.miniapp.service.IUserTokenInfoService; +import com.xiang.service.module.jntyzx.miniapp.service.IVenueService; +import com.xiang.service.module.jntyzx.miniapp.utils.VenueInfoUtils; +import com.xiang.service.module.jntyzx.miniapp.utils.WeekendUtils; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.CollectionUtils; +import org.springframework.stereotype.Component; + +import java.time.LocalDate; +import java.util.List; +import java.util.Map; +import java.util.Objects; + +@Slf4j +@Component +public class JtVenueTomorrowPullTask extends BaseScheduleTaskTemplate { + private final IUserTokenInfoService userTokenInfoService; + private final IJntyzxHttpService jntyzxHttpService; + private final JntyzxDingTalkFactory jtDingTalkFactory; + private final IVenueService venueService; + + public JtVenueTomorrowPullTask(IScheduleOpeningConfigService scheduleOpeningConfigService, + IScheduleRunLogService scheduleRunLogService, + IUserTokenInfoService userTokenInfoService, + IJntyzxHttpService jntyzxHttpService, + JntyzxDingTalkFactory jtDingTalkFactory, + IVenueService venueService) { + super(scheduleOpeningConfigService, scheduleRunLogService); + this.userTokenInfoService = userTokenInfoService; + this.jntyzxHttpService = jntyzxHttpService; + this.jtDingTalkFactory = jtDingTalkFactory; + this.venueService = venueService; + } + + @Override + protected String getTaskName() { + return ScheduleEnums.JNTYZX_VENUE_TOMORROW_PULL_TASK.getTaskName(); + } + + @Override + protected Integer getModule() { + return ScheduleEnums.JNTYZX_VENUE_TOMORROW_PULL_TASK.getModuleCode(); + } + + @Override + protected String getModuleName() { + return ScheduleEnums.JNTYZX_VENUE_TOMORROW_PULL_TASK.getModule(); + } + + @Override + protected TaskResult doExecute(Object validatedParams) throws Exception { + TaskResult taskResult = new TaskResult(); + taskResult.setSuccess(Boolean.FALSE); + log.info("【Venue】江体小程序场地拉取定时任务启动!!!time:{}", System.currentTimeMillis()); + List availableUser = userTokenInfoService.getAvailableUser(); + if (CollectionUtils.isEmpty(availableUser)) { + log.info("当前无可用用户查询场地信息!"); + taskResult.setSummary("当前无可用用户查询场地信息"); + return taskResult; + } + // 用户信息 + StringBuffer userMsg = new StringBuffer(); + availableUser.forEach(item -> { + JntyzxResponse jntyzxResponse = jntyzxHttpService.checkDefaultNums(item.getToken(), item.getMemberCardNo()); + if (Objects.nonNull(jntyzxResponse)) { + if (jntyzxResponse.getSuccess()) { + userMsg.append("订购人:").append(item.getName()).append("正常下单\n"); + } else { + userMsg.append("订购人:").append(item.getName()).append(jntyzxResponse.getMessage()).append("\n"); + } + } + }); + jtDingTalkFactory.sendMsg(userMsg.toString()); + + // 场地信息 + UserTokenInfoDO userTokenInfoDO = availableUser.get(0); + String token = userTokenInfoDO.getToken(); + List sitePositionLists = jntyzxHttpService.queryAvailableTomorrow(WeekendUtils.isWeekend(), token); + if (CollectionUtils.isEmpty(sitePositionLists)) { + taskResult.setSummary("当前无可用场地信息"); + return taskResult; + } + venueService.saveTomorrowVenueInfo(sitePositionLists); + sitePositionLists = sitePositionLists.stream().filter(VenueInfoUtils::get8210VenueInfo).toList(); + if (CollectionUtils.isEmpty(sitePositionLists)) { + taskResult.setSummary("当前无可用场地信息"); + return taskResult; + } + Map map = Maps.newLinkedHashMap(); + for (SitePositionList sitePositionList : sitePositionLists) { + if (map.containsKey(sitePositionList.getPlaceName())) { + continue; + } + map.put(sitePositionList.getPlaceName(), sitePositionList); + } + StringBuffer msg = new StringBuffer("查询江体场地信息=====>\n时间:" + DateUtils.getDateFromDate(LocalDate.now().plusDays(1)) + " 20:00-22:00\n"); + map.forEach((placeName, sitePositionList) -> { + msg.append(placeName).append("订购人:").append(sitePositionList.getContacts()).append("\n"); + }); + jtDingTalkFactory.sendMsg(msg.toString()); + + taskResult.setSuccess(Boolean.TRUE); + taskResult.setSummary("场地信息获取成功!"); + return taskResult; + } +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IUserInfoService.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IUserInfoService.java new file mode 100644 index 0000000..bf7eaea --- /dev/null +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IUserInfoService.java @@ -0,0 +1,16 @@ +package com.xiang.service.module.jntyzx.miniapp.service; + +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserInfoDO; + +import java.util.List; + +/** + * @Author: xiang + * @Date: 2026-05-09 10:00 + */ +public interface IUserInfoService { + + boolean delAll(); + + boolean batchSave(List list); +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IUserTokenInfoService.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IUserTokenInfoService.java index 5a6b0bc..a28abc8 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IUserTokenInfoService.java +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IUserTokenInfoService.java @@ -2,9 +2,6 @@ package com.xiang.service.module.jntyzx.miniapp.service; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; -import com.xiang.common.pojo.jntyzx.miniapp.req.UserAddReq; -import com.xiang.common.pojo.jntyzx.miniapp.req.UserQueryReq; -import com.xiang.common.pojo.jntyzx.miniapp.resp.JtUserVo; import java.util.List; @@ -20,14 +17,4 @@ public interface IUserTokenInfoService { boolean flushSingleToken(String name); boolean flushToken(); boolean updateTokenByName(String name, String token); - - List list(UserQueryReq req); - - Boolean updateStatusByUserName(String username, Integer status); - - Boolean refreshToken(String username); - - Boolean save(UserAddReq req); - - JtUserVo info(Long userId); } diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IVenueService.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IVenueService.java index 78733c8..4a82ea1 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IVenueService.java +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/IVenueService.java @@ -1,10 +1,7 @@ package com.xiang.service.module.jntyzx.miniapp.service; -import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.xiang.common.pojo.jntyzx.miniapp.pojo.VenueInfoDO; -import com.xiang.common.pojo.jntyzx.miniapp.req.VenueInfoQueryRequest; -import com.xiang.common.pojo.jntyzx.miniapp.resp.VenueInfoQueryResp; import com.xiang.common.pojo.jntyzx.miniapp.resp.query.SitePositionList; import java.util.List; @@ -34,11 +31,4 @@ public interface IVenueService { * @return */ boolean saveTomorrowVenueInfo(List sitePositionLists); - - /** - * 查询场地列表信息 - * @param request - * @return - */ - Page list(VenueInfoQueryRequest request); } diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/JntyzxHttpServiceImpl.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/JntyzxHttpServiceImpl.java index d1ff885..7f825d4 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/JntyzxHttpServiceImpl.java +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/JntyzxHttpServiceImpl.java @@ -13,9 +13,11 @@ import com.xiang.common.pojo.jntyzx.miniapp.resp.OrderCreateResp; import com.xiang.common.pojo.jntyzx.miniapp.resp.query.SitePositionList; import com.xiang.common.pojo.jntyzx.miniapp.resp.query.UserInfoResponse; import com.xiang.common.pojo.jntyzx.miniapp.resp.query.VenueList; +import com.xiang.common.utils.HttpService; +import com.xiang.common.utils.JsonUtils; import com.xiang.common.utils.RedisService; -import com.xiang.service.module.jntyzx.miniapp.constants.UrlConstant; -import com.xiang.service.module.jntyzx.miniapp.manage.IOrderCreateInfoManage; +import com.xiang.common.enums.JntyzxUrlConstant; +import com.xiang.common.manage.jntyzx.miniapp.IOrderCreateInfoManage; import com.xiang.service.module.jntyzx.miniapp.service.IJntyzxHttpService; import com.xiang.service.module.jntyzx.miniapp.utils.JntyzxSaltEncodeUtils; import lombok.RequiredArgsConstructor; @@ -43,7 +45,7 @@ public class JntyzxHttpServiceImpl implements IJntyzxHttpService { @Override public List queryAvailable(String isWeekend, String token) { - String url = UrlConstant.QUERY_TODAY_SUBSCRIBE_URL; + String url = JntyzxUrlConstant.QUERY_TODAY_SUBSCRIBE_URL; return querySitePositionInfo(isWeekend, token, url); } @@ -56,7 +58,7 @@ public class JntyzxHttpServiceImpl implements IJntyzxHttpService { params.put("gid", "03"); params.put("isWeekend", isWeekend); try { - resp = HttpHelper.doGet(url, header, params); + resp = HttpService.doGet(url, header, params); } catch (Exception e) { log.error("[doGet] 江南体育中心查询当天场地 请求失败, url:{}", url); return Lists.newArrayList(); @@ -98,7 +100,7 @@ public class JntyzxHttpServiceImpl implements IJntyzxHttpService { @Override public List queryAvailableTomorrow(String isWeekend, String token) { - String url = UrlConstant.QUERY_TOMORROW_SUBSCRIBE_URL; + String url = JntyzxUrlConstant.QUERY_TOMORROW_SUBSCRIBE_URL; return querySitePositionInfo(isWeekend, token, url); } @@ -143,7 +145,7 @@ public class JntyzxHttpServiceImpl implements IJntyzxHttpService { Map params = Maps.newHashMap(); params.put("X-Access-Token", token); - String resp = HttpHelper.doPost(UrlConstant.ADD_SUBSCRIBE, params, JsonUtils.toJsonString(subscribeRequest)); + String resp = HttpService.doPost(JntyzxUrlConstant.ADD_SUBSCRIBE, params, JsonUtils.toJsonString(subscribeRequest)); log.info("[江体小程序] 羽毛球场地下单响应结果:{}", resp); if (StringUtils.isBlank(resp)) { log.info("[resp] 请求结果为空"); @@ -164,7 +166,7 @@ public class JntyzxHttpServiceImpl implements IJntyzxHttpService { Map params = Maps.newHashMap(); params.put("openId", openId); - String respStr = HttpHelper.doGet(UrlConstant.HEALTH_DECLARATION, headers, params); + String respStr = HttpService.doGet(JntyzxUrlConstant.HEALTH_DECLARATION, headers, params); if (StringUtils.isBlank(respStr)) { return null; } @@ -178,7 +180,7 @@ public class JntyzxHttpServiceImpl implements IJntyzxHttpService { Map headers = Maps.newHashMap(); headers.put("X-Access-Token", token); - String resp = HttpHelper.doGet(UrlConstant.QUERY_BY_OPEN_ID, headers, params); + String resp = HttpService.doGet(JntyzxUrlConstant.QUERY_BY_OPEN_ID, headers, params); JntyzxResponse response = JSON.parseObject(resp, new TypeReference>() { }); if (Objects.isNull(response)) { @@ -195,7 +197,7 @@ public class JntyzxHttpServiceImpl implements IJntyzxHttpService { Map headers = Maps.newHashMap(); headers.put("X-Access-Token", token); - String resp = HttpHelper.doGet(UrlConstant.CHECK_NUM, headers, params); + String resp = HttpService.doGet(JntyzxUrlConstant.CHECK_NUM, headers, params); if (StringUtils.isBlank(resp)) { return null; } diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/OrderInfoServiceImpl.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/OrderInfoServiceImpl.java index 5adff5a..004e686 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/OrderInfoServiceImpl.java +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/OrderInfoServiceImpl.java @@ -2,14 +2,15 @@ package com.xiang.service.module.jntyzx.miniapp.service.impl; import com.alibaba.fastjson2.JSON; import com.xiang.common.exception.BusinessException; +import com.xiang.common.factory.JntyzxDingTalkFactory; import com.xiang.common.pojo.jntyzx.miniapp.pojo.OrderInfoDO; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; import com.xiang.common.pojo.jntyzx.miniapp.pojo.VenueInfoDO; import com.xiang.common.pojo.jntyzx.miniapp.resp.JntyzxResponse; import com.xiang.common.pojo.jntyzx.miniapp.resp.OrderCreateResp; import com.xiang.common.utils.RedisService; -import com.xiang.service.module.jntyzx.miniapp.constants.RedisKeyConstant; -import com.xiang.service.module.jntyzx.miniapp.manage.IOrderCreateInfoManage; +import com.xiang.common.enums.RedisKeyConstant; +import com.xiang.common.manage.jntyzx.miniapp.IOrderCreateInfoManage; import com.xiang.service.module.jntyzx.miniapp.service.IJntyzxHttpService; import com.xiang.service.module.jntyzx.miniapp.service.IJtOrderService; import lombok.RequiredArgsConstructor; @@ -34,7 +35,7 @@ public class OrderInfoServiceImpl implements IJtOrderService { private final IOrderCreateInfoManage orderCreateInfoManage; private final IJntyzxHttpService jntyzxHttpService; private final RedisService redisService; - private final JntyzxHttpServiceImpl dingTalkFactory; + private final JntyzxDingTalkFactory dingTalkFactory; @Override public List queryNoPayOrder() { return orderCreateInfoManage.queryNoPayOrder(); diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/UserInfoServiceImpl.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/UserInfoServiceImpl.java new file mode 100644 index 0000000..7f3c316 --- /dev/null +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/UserInfoServiceImpl.java @@ -0,0 +1,32 @@ +package com.xiang.service.module.jntyzx.miniapp.service.impl; + +import com.xiang.common.manage.jntyzx.miniapp.IUserInfoManage; +import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserInfoDO; +import com.xiang.service.module.jntyzx.miniapp.service.IUserInfoService; +import lombok.RequiredArgsConstructor; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * @Author: xiang + * @Date: 2026-05-09 10:18 + */ +@Service +@Slf4j +@RequiredArgsConstructor +public class UserInfoServiceImpl implements IUserInfoService { + + private final IUserInfoManage userInfoManage; + + @Override + public boolean delAll() { + return userInfoManage.delAll(); + } + + @Override + public boolean batchSave(List list) { + return userInfoManage.saveBatch(list); + } +} diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/UserTokenInfoServiceImpl.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/UserTokenInfoServiceImpl.java index bdc94db..2e15e50 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/UserTokenInfoServiceImpl.java +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/UserTokenInfoServiceImpl.java @@ -1,20 +1,15 @@ package com.xiang.service.module.jntyzx.miniapp.service.impl; -import com.google.common.collect.Lists; -import com.google.common.collect.Maps; +import com.alibaba.fastjson.JSONObject; import com.xiang.common.exception.BusinessException; import com.xiang.common.factory.JntyzxDingTalkFactory; +import com.xiang.common.manage.jntyzx.miniapp.IUserRestrictionManage; +import com.xiang.common.manage.jntyzx.miniapp.IUserTokenInfoManage; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserRestrictionInfo; import com.xiang.common.pojo.jntyzx.miniapp.pojo.UserTokenInfoDO; -import com.xiang.common.pojo.jntyzx.miniapp.req.UserAddReq; -import com.xiang.common.pojo.jntyzx.miniapp.req.UserQueryReq; import com.xiang.common.pojo.jntyzx.miniapp.resp.JntyzxResponse; -import com.xiang.common.pojo.jntyzx.miniapp.resp.JtUserVo; import com.xiang.common.pojo.jntyzx.miniapp.resp.query.UserInfoResponse; import com.xiang.common.utils.DateUtils; -import com.xiang.service.module.jntyzx.miniapp.converts.UserConverter; -import com.xiang.service.module.jntyzx.miniapp.manage.IUserRestrictionManage; -import com.xiang.service.module.jntyzx.miniapp.manage.IUserTokenInfoManage; import com.xiang.service.module.jntyzx.miniapp.service.IJntyzxHttpService; import com.xiang.service.module.jntyzx.miniapp.service.IUserTokenInfoService; import lombok.RequiredArgsConstructor; @@ -23,12 +18,8 @@ import org.apache.commons.collections4.CollectionUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Service; -import java.time.LocalDateTime; import java.util.List; -import java.util.Map; import java.util.Objects; -import java.util.function.Function; -import java.util.stream.Collectors; /** * @Author: xiang @@ -43,7 +34,6 @@ public class UserTokenInfoServiceImpl implements IUserTokenInfoService { private final IJntyzxHttpService jntyzxHttpService; private final JntyzxDingTalkFactory jtDingTalkFactory; private final IUserRestrictionManage userRestrictionManage; - private final UserConverter userConverter; @Override @@ -103,6 +93,10 @@ public class UserTokenInfoServiceImpl implements IUserTokenInfoService { } private boolean healthDeclaration(UserTokenInfoDO userTokenInfoDO) { + if (StringUtils.isBlank(userTokenInfoDO.getToken()) || StringUtils.isBlank(userTokenInfoDO.getOpenId())) { + log.info("用户信息异常:{}", JSONObject.toJSONString(userTokenInfoDO)); + return false; + } JntyzxResponse jntyzxResponse = jntyzxHttpService.healthDeclaration(userTokenInfoDO.getToken(), userTokenInfoDO.getOpenId()); if (Objects.isNull(jntyzxResponse)) { log.info("用户名:{}心跳监测失败!", userTokenInfoDO.getName()); @@ -120,97 +114,6 @@ public class UserTokenInfoServiceImpl implements IUserTokenInfoService { return flag; } - @Override - public List list(UserQueryReq req) { - List userTokenInfoDOS = userTokenInfoManage.queryByList(req); - if (CollectionUtils.isEmpty(userTokenInfoDOS)) { - return Lists.newArrayList(); - } - List idList = userTokenInfoDOS.stream().map(UserTokenInfoDO::getId).toList(); - List userRestrictionInfos = userRestrictionManage.queryByIdList(idList); - Map userRestrictionInfoMap = Maps.newHashMap(); - if (CollectionUtils.isNotEmpty(userRestrictionInfos)) { - userRestrictionInfoMap.putAll( - userRestrictionInfos.stream().collect(Collectors.toMap( - UserRestrictionInfo::getUserId, Function.identity(), (a, b) -> a))); - } - List jtUserVoList = userConverter.convert(userTokenInfoDOS); - jtUserVoList.forEach(item -> { - if (userRestrictionInfoMap.containsKey(item.getUserId())) { - UserRestrictionInfo userRestrictionInfo = userRestrictionInfoMap.get(item.getUserId()); - if (Objects.nonNull(userRestrictionInfo)) { - if (userRestrictionInfo.getRestrictionDeadline().isAfter(LocalDateTime.now())) { - item.setRestrictionDeadline(userRestrictionInfo.getRestrictionDeadline()); - item.setRestrictionDesc(userRestrictionInfo.getRestrictionDesc()); - } - } - } - }); - return jtUserVoList; - } - - @Override - public Boolean updateStatusByUserName(String username, Integer status) { - if (StringUtils.isEmpty(username)) { - log.error("用户名为空"); - return false; - } - UserTokenInfoDO userTokenInfoDO = userTokenInfoManage.getByName(username); - if (Objects.isNull(userTokenInfoDO)) { - throw new BusinessException("用户不存在!"); - } - userTokenInfoDO.setStatus(status); - return userTokenInfoManage.updateById(userTokenInfoDO); - } - - @Override - public Boolean refreshToken(String username) { - if (StringUtils.isEmpty(username)) { - log.error("用户名为空"); - return false; - } - UserTokenInfoDO userTokenInfoDO = userTokenInfoManage.getByName(username); - if (Objects.isNull(userTokenInfoDO)) { - throw new BusinessException("用户不存在!"); - } - return healthDeclaration(userTokenInfoDO); - } - - @Override - public Boolean save(UserAddReq req) { - UserTokenInfoDO userTokenInfoDO = userTokenInfoManage.getByName(req.getName()); - if (Objects.nonNull(userTokenInfoDO)) { - throw new BusinessException("用户名已存在!"); - } - userTokenInfoDO = new UserTokenInfoDO(); - userTokenInfoDO.setName(req.getName()); - userTokenInfoDO.setToken(req.getToken()); - userTokenInfoDO.setOpenId(req.getOpenId()); - userTokenInfoDO.setStatus(req.getStatus()); - userTokenInfoDO.setIsOrder(1); - userTokenInfoDO.setMemberCardNo(req.getMemberCardNo()); - userTokenInfoDO.setIsRestriction(0); - userTokenInfoDO.setUpdateTime(LocalDateTime.now()); - return userTokenInfoManage.save(userTokenInfoDO); - } - - @Override - public JtUserVo info(Long userId) { - UserTokenInfoDO userTokenInfoDO = userTokenInfoManage.getById(userId); - if (Objects.isNull(userTokenInfoDO)) { - throw new BusinessException("用户不存在!"); - } - JtUserVo jtUserVo = userConverter.convert(userTokenInfoDO); - UserRestrictionInfo userRestrictionInfo = userRestrictionManage.queryByUserId(userId); - if (Objects.nonNull(userRestrictionInfo)) { - if (userRestrictionInfo.getRestrictionDeadline().isAfter(LocalDateTime.now())) { - jtUserVo.setRestrictionDeadline(userRestrictionInfo.getRestrictionDeadline()); - jtUserVo.setRestrictionDesc(userRestrictionInfo.getRestrictionDesc()); - } - } - return jtUserVo; - } - /** * 查询用户信息 * @@ -219,6 +122,10 @@ public class UserTokenInfoServiceImpl implements IUserTokenInfoService { * @return */ private void queryMemberCardInfo(UserTokenInfoDO userTokenInfoDO) { + if (StringUtils.isBlank(userTokenInfoDO.getToken()) || StringUtils.isBlank(userTokenInfoDO.getOpenId())) { + log.info("用户信息异常:{}", JSONObject.toJSONString(userTokenInfoDO)); + return; + } JntyzxResponse response = jntyzxHttpService.queryByOpenId(userTokenInfoDO.getToken(), userTokenInfoDO.getOpenId()); if (Objects.isNull(response)) { return; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/VenueServiceImpl.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/VenueServiceImpl.java index 058af34..82dc080 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/VenueServiceImpl.java +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/service/impl/VenueServiceImpl.java @@ -1,15 +1,11 @@ package com.xiang.service.module.jntyzx.miniapp.service.impl; -import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.google.common.collect.Lists; import com.google.common.collect.Maps; import com.xiang.common.pojo.jntyzx.miniapp.pojo.VenueInfoDO; -import com.xiang.common.pojo.jntyzx.miniapp.req.VenueInfoQueryRequest; -import com.xiang.common.pojo.jntyzx.miniapp.resp.VenueInfoQueryResp; import com.xiang.common.pojo.jntyzx.miniapp.resp.query.SitePositionList; import com.xiang.common.utils.DateUtils; -import com.xiang.service.module.jntyzx.miniapp.converts.VenueInfoConverter; -import com.xiang.service.module.jntyzx.miniapp.manage.IVenueInfoManage; +import com.xiang.common.manage.jntyzx.miniapp.IVenueInfoManage; import com.xiang.service.module.jntyzx.miniapp.service.IJntyzxHttpService; import com.xiang.service.module.jntyzx.miniapp.service.IUserTokenInfoService; import com.xiang.service.module.jntyzx.miniapp.service.IVenueService; @@ -38,7 +34,6 @@ public class VenueServiceImpl implements IVenueService { private final IJntyzxHttpService jntyzxHttpService; private final IVenueInfoManage venueInfoManage; private final IUserTokenInfoService userTokenInfoService; - private final VenueInfoConverter venueInfoConverter; @Override public List queryVenueService() { @@ -160,12 +155,6 @@ public class VenueServiceImpl implements IVenueService { return true; } - @Override - public Page list(VenueInfoQueryRequest request) { - Page page = venueInfoManage.page(request); - return venueInfoConverter.toPage(page); - } - private void updateDatabase(List list, boolean isToday) { List venueInfoDOS = Lists.newArrayList(); if (isToday) { diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/utils/MsgSendUtils.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/utils/MsgSendUtils.java index 077e865..ab0b174 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/utils/MsgSendUtils.java +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/utils/MsgSendUtils.java @@ -2,7 +2,7 @@ package com.xiang.service.module.jntyzx.miniapp.utils; import com.xiang.common.factory.JntyzxDingTalkFactory; import com.xiang.common.utils.RedisService; -import com.xiang.service.module.jntyzx.miniapp.constants.RedisKeyConstant; +import com.xiang.common.enums.RedisKeyConstant; import lombok.RequiredArgsConstructor; import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Component; diff --git a/src/main/java/com/xiang/service/module/jntyzx/miniapp/utils/VenueInfoUtils.java b/src/main/java/com/xiang/service/module/jntyzx/miniapp/utils/VenueInfoUtils.java index 464962d..f621f25 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/miniapp/utils/VenueInfoUtils.java +++ b/src/main/java/com/xiang/service/module/jntyzx/miniapp/utils/VenueInfoUtils.java @@ -30,12 +30,18 @@ public class VenueInfoUtils { if (placeName.contains("十号")) { return 0; } - if (placeName.contains("二号")) { + if (placeName.contains("九号")) { return 1; } - if (placeName.contains("九号")) { + if (placeName.contains("二号")) { return 2; } - return 3; + if (placeName.contains("八号")) { + return 3; + } + if (placeName.contains("七号")) { + return 4; + } + return 5; } } diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbLoginTask.java b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbLoginTask.java index f15a018..bade2eb 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbLoginTask.java +++ b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbLoginTask.java @@ -13,7 +13,7 @@ import com.xiang.common.pojo.jntyzx.zlb.ZlbTokenInfo; import com.xiang.common.pojo.schedule.TaskResult; import com.xiang.common.service.IScheduleOpeningConfigService; import com.xiang.common.service.IScheduleRunLogService; -import com.xiang.service.module.jntyzx.zlb.service.ZlbTokenInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbTokenInfoService; import lombok.extern.slf4j.Slf4j; import okhttp3.MediaType; import okhttp3.OkHttpClient; @@ -53,7 +53,7 @@ public class ZlbLoginTask extends BaseScheduleTaskTemplate { @Override protected Integer getModule() { - return ScheduleEnums.ZLB_LOGIN_TASK.getModeleCode(); + return ScheduleEnums.ZLB_LOGIN_TASK.getModuleCode(); } @Override diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbOrderTask.java b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbOrderTask.java index fc702ab..8f83c64 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbOrderTask.java +++ b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbOrderTask.java @@ -17,8 +17,8 @@ import com.xiang.common.utils.DateUtils; import com.xiang.common.utils.OkHttpUtil; import com.xiang.service.module.jntyzx.zlb.constants.ZlbUrlConstants; import com.xiang.service.module.jntyzx.zlb.service.ZlbService; -import com.xiang.service.module.jntyzx.zlb.service.ZlbTokenInfoService; -import com.xiang.service.module.jntyzx.zlb.service.ZlbUserInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbTokenInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbUserInfoService; import lombok.extern.slf4j.Slf4j; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; @@ -63,7 +63,7 @@ public class ZlbOrderTask extends BaseScheduleTaskTemplate { @Override protected Integer getModule() { - return ScheduleEnums.ZLB_ORDER_CREATE_TASK.getModeleCode(); + return ScheduleEnums.ZLB_ORDER_CREATE_TASK.getModuleCode(); } @Override @@ -108,23 +108,33 @@ public class ZlbOrderTask extends BaseScheduleTaskTemplate { //计算9点到现在的时间差 //获取江体当前时间 LocalTime currentTime = LocalTime.now(); - LocalTime targetTime = LocalTime.parse("09:00:11.800"); + LocalTime targetTime = LocalTime.parse("09:00:12.500"); Duration duration = Duration.between(currentTime, targetTime); long milliseconds = duration.toMillis(); executorService.schedule(() -> { - String response = null; - try { - response = client.postJson(ZlbUrlConstants.newOrderUrl, headers, newOrderJson); - } catch (Exception e) { - throw new RuntimeException(e); + for (int i = 0; i < 3; i++) { + String response = null; + try { + response = client.postJson(ZlbUrlConstants.newOrderUrl, headers, newOrderJson); + } catch (Exception e) { + throw new RuntimeException(e); + } + boolean b = buildOrder(name, response, placeName, siteTimeName); + if (b) { + break; + } + try { + Thread.sleep(1250); + } catch (InterruptedException e) { + logger.error("线程暂停异常"); + } } - buildOrder(name, response, placeName, siteTimeName); }, milliseconds, TimeUnit.MILLISECONDS); return taskResult; } - private void buildOrder(String name, String response, String placeName, String siteTimeName) { + private boolean buildOrder(String name, String response, String placeName, String siteTimeName) { log.info("订单接口返回结果==> \n {}", response); JSONObject jsonObject = JSONObject.parseObject(response); if (jsonObject.getInteger("code") == 200) { @@ -135,6 +145,14 @@ public class ZlbOrderTask extends BaseScheduleTaskTemplate { String redisKey = ZlbUrlConstants.REDIS_PREFIX + "_" + orderId + "_" + name; redisTemplate.opsForValue().set(redisKey, name); redisTemplate.expire(redisKey, 120, TimeUnit.SECONDS); + return true; } + if (jsonObject.getInteger("code") == 500) { + if (jsonObject.getString("message").contains("已被售出")) { + jntyzxDingTalkFactory.sendMsg(name + "订单接口下单返回失败❌❌❌场地号:" + placeName + "已被售出"); + return true; + } + } + return false; } } diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbSiteDayTask.java b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbSiteDayTask.java index 1a17e02..c4127c0 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbSiteDayTask.java +++ b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbSiteDayTask.java @@ -14,7 +14,6 @@ import com.xiang.common.utils.DateUtils; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Component; -import javax.annotation.Resource; import java.util.Date; import java.util.List; @@ -40,7 +39,7 @@ public class ZlbSiteDayTask extends BaseScheduleTaskTemplate { @Override protected Integer getModule() { - return ScheduleEnums.ZLB_SITE_DAY_TASK.getModeleCode(); + return ScheduleEnums.ZLB_SITE_DAY_TASK.getModuleCode(); } @Override diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbSiteTask.java b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbSiteTask.java index bf65ed1..dcb236f 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbSiteTask.java +++ b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbSiteTask.java @@ -30,7 +30,7 @@ public class ZlbSiteTask extends BaseScheduleTaskTemplate { @Override protected Integer getModule() { - return ScheduleEnums.ZLB_SITE_QUERY_TASK.getModeleCode(); + return ScheduleEnums.ZLB_SITE_QUERY_TASK.getModuleCode(); } @Override diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbTaskConfig.java b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbTaskConfig.java index 812f2f8..b8f5040 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbTaskConfig.java +++ b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbTaskConfig.java @@ -43,7 +43,7 @@ public class ZlbTaskConfig { } @GetMapping("/zlbOrderCreateTask") - @Scheduled(cron = "55 59 8 * * ?") + @Scheduled(cron = "2 0 9 * * ?") public void zlbOrderCreateTask() { zlbOrderTask.run(); } diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbTokenRefreshTask.java b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbTokenRefreshTask.java index 17a360f..df98213 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbTokenRefreshTask.java +++ b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbTokenRefreshTask.java @@ -9,12 +9,11 @@ import com.xiang.common.pojo.jntyzx.zlb.ZlbTokenInfo; import com.xiang.common.pojo.schedule.TaskResult; import com.xiang.common.service.IScheduleOpeningConfigService; import com.xiang.common.service.IScheduleRunLogService; -import com.xiang.service.module.jntyzx.zlb.service.ZlbTokenInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbTokenInfoService; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Component; -import javax.annotation.Resource; import java.util.Date; import java.util.List; @@ -41,7 +40,7 @@ public class ZlbTokenRefreshTask extends BaseScheduleTaskTemplate { @Override protected Integer getModule() { - return ScheduleEnums.ZLB_TOKEN_CHECK_TASK.getModeleCode(); + return ScheduleEnums.ZLB_TOKEN_CHECK_TASK.getModuleCode(); } @Override diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbUserConfigTask.java b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbUserConfigTask.java index 7f10448..6685db4 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbUserConfigTask.java +++ b/src/main/java/com/xiang/service/module/jntyzx/zlb/schedule/ZlbUserConfigTask.java @@ -13,9 +13,10 @@ import com.xiang.common.pojo.schedule.TaskResult; import com.xiang.common.service.IScheduleOpeningConfigService; import com.xiang.common.service.IScheduleRunLogService; import com.xiang.common.utils.DateUtils; -import com.xiang.service.module.jntyzx.zlb.service.ZlbSiteInfoService; -import com.xiang.service.module.jntyzx.zlb.service.ZlbTokenInfoService; -import com.xiang.service.module.jntyzx.zlb.service.ZlbUserInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbSiteInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbTokenInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbUserInfoService; +import com.xiang.service.module.jntyzx.miniapp.utils.VenueInfoUtils; import lombok.extern.slf4j.Slf4j; import org.apache.commons.collections4.CollectionUtils; import org.springframework.stereotype.Component; @@ -59,7 +60,7 @@ public class ZlbUserConfigTask extends BaseScheduleTaskTemplate { @Override protected Integer getModule() { - return ScheduleEnums.ZLB_USER_CONFIG_TASK.getModeleCode(); + return ScheduleEnums.ZLB_USER_CONFIG_TASK.getModuleCode(); } @Override @@ -133,26 +134,6 @@ public class ZlbUserConfigTask extends BaseScheduleTaskTemplate { if (CollectionUtils.isEmpty(siteInfoList)) { return Lists.newArrayList(); } - return siteInfoList.stream().sorted(Comparator.comparing(this::sort)).collect(Collectors.toList()); - } - - private int sort(ZlbSiteInfo siteInfo) { - String placeName = siteInfo.getPlaceName(); - if (placeName.contains("十号")) { - return 0; - } - if (placeName.contains("九号")) { - return 1; - } - if (placeName.contains("二号")) { - return 2; - } - if (placeName.contains("八号")) { - return 3; - } - if (placeName.contains("七号")) { - return 4; - } - return 5; + return siteInfoList.stream().sorted(Comparator.comparing(item -> VenueInfoUtils.sortVenueInfo(item.getPlaceName()))).collect(Collectors.toList()); } } diff --git a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbServiceImpl.java b/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbServiceImpl.java index fd10a36..1dc4cab 100644 --- a/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbServiceImpl.java +++ b/src/main/java/com/xiang/service/module/jntyzx/zlb/service/ZlbServiceImpl.java @@ -9,6 +9,9 @@ import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.xiang.common.factory.JntyzxDingTalkFactory; +import com.xiang.common.manage.jntyzx.zlb.ZlbSiteInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbTokenInfoService; +import com.xiang.common.manage.jntyzx.zlb.ZlbUserInfoService; import com.xiang.common.pojo.jntyzx.zlb.ZlbCaptchaResp; import com.xiang.common.pojo.jntyzx.zlb.ZlbOrderInfo; import com.xiang.common.pojo.jntyzx.zlb.ZlbOrderJson;