| | |
| | | import com.doumee.core.constants.Constants; |
| | | import com.doumee.core.constants.ResponseStatus; |
| | | import com.doumee.core.exception.BusinessException; |
| | | import com.doumee.core.constants.ResponseStatus; |
| | | import com.doumee.core.exception.BusinessException; |
| | | import com.doumee.core.model.LoginUserInfo; |
| | | import com.doumee.core.model.PageData; |
| | | import com.doumee.core.model.PageWrap; |
| | | import com.doumee.core.utils.DateUtil; |
| | | import com.doumee.core.utils.Utils; |
| | | import com.doumee.dao.business.GoodsorderMapper; |
| | | import com.doumee.dao.business.LocksMapper; |
| | | import com.doumee.dao.business.ActionLogMapper; |
| | | import com.doumee.dao.business.MemberRidesMapper; |
| | | import com.doumee.dao.business.join.MemberRidesJoinMapper; |
| | | import com.doumee.dao.business.model.*; |
| | | import com.doumee.dao.business.model.BaseParam; |
| | | import com.doumee.dao.business.model.Goodsorder; |
| | | import com.doumee.dao.business.model.Member; |
| | | import com.doumee.dao.business.model.MemberRides; |
| | | import com.doumee.dao.business.model.*; |
| | | import com.doumee.dao.business.web.request.MemberRidesQuery; |
| | | import com.doumee.dao.business.web.response.BikeLogDTO; |
| | | import com.doumee.dao.business.web.response.MemberRidesDTO; |
| | | import com.doumee.dao.business.web.response.MemberRidesDetailResponse; |
| | | import com.doumee.service.business.DeviceService; |
| | | import com.doumee.service.business.GoodsorderService; |
| | | import com.doumee.service.business.MemberRidesService; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; |
| | |
| | | import com.github.yulichang.wrapper.MPJLambdaWrapper; |
| | | import org.apache.commons.lang3.StringUtils; |
| | | import org.apache.shiro.SecurityUtils; |
| | | import org.checkerframework.checker.units.qual.C; |
| | | import org.springframework.beans.BeanUtils; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | |
| | | @Autowired |
| | | private ActionLogMapper actionLogMapper; |
| | | |
| | | |
| | | @Autowired |
| | | private MemberRidesJoinMapper memberRidesJoinMapper; |
| | | |
| | | @Autowired |
| | | private DeviceService deviceService; |
| | | |
| | | @Autowired |
| | | private LocksMapper locksMapper; |
| | | |
| | | @Autowired |
| | | private GoodsorderService goodsorderService; |
| | | |
| | | @Override |
| | | public String create(MemberRides memberRides) { |
| | |
| | | Constants.formatIntegerNum(model.getCloseStatus()) != Constants.ONE){ |
| | | throw new BusinessException( ResponseStatus.NOT_ALLOWED.getCode(),"对不起,只能针对已还车且未结算的数据进行操作!" ); |
| | | } |
| | | if(Constants.formatIntegerNum(memberRides.getDuration()) == Constants.formatIntegerNum(model.getDuration())){ |
| | | throw new BusinessException( ResponseStatus.BAD_REQUEST.getCode(),"对不起,时长未发生改变,无需修改!" ); |
| | | } |
| | | int actTime = DateUtil.betweenMin(model.getRentDate(), model.getBackDate()); |
| | | if(memberRides.getDuration() > actTime){ |
| | | throw new BusinessException( ResponseStatus.BAD_REQUEST.getCode(),"对不起,计费时长不能超过实际借出时长!" ); |
| | | } |
| | | MemberRides update = new MemberRides(); |
| | | update.setId(model.getId()); |
| | | update.setDuration(memberRides.getDuration()); |
| | |
| | | } |
| | | |
| | | |
| | | @Override |
| | | public MemberRidesDetailResponse openLock(String code,String memberId){ |
| | | //判断当前是否已支付押金 |
| | | Goodsorder goodsorder = goodsorderService.findOneByWrapper(new QueryWrapper<Goodsorder>() |
| | | .eq("isdeleted",Constants.ZERO) |
| | | .eq("status",Constants.goodsorderStatus.pay) |
| | | .eq("member_id",memberId) |
| | | .orderByDesc("create_date") |
| | | .last("limit 1")); |
| | | if(Objects.isNull(goodsorder)){ |
| | | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"未支付押金,无法进行该操作!"); |
| | | } |
| | | //判断当前押金订单是否为今日押金 |
| | | if(!DateUtil.DateToStr(goodsorder.getPayDate(),"yyyy-MM-dd").equals(DateUtil.getDate(new Date(),"yyyy-MM-dd"))){ |
| | | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"非今日押金订单,请结算后重新支付!"); |
| | | } |
| | | //判断是否处于营业时间 |
| | | goodsorderService.checkBusiness(); |
| | | //查询是否处于骑行中 |
| | | if(memberRidesMapper.selectCount(new QueryWrapper<MemberRides>().eq("member_id",memberId).in("status",0,1))>Constants.ZERO){ |
| | | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"存在骑行中车辆,无法扫码"); |
| | | }; |
| | | Locks locks = locksMapper.selectOne(new QueryWrapper<Locks>().eq("code",code).eq("isdeleted", Constants.ZERO).last("limit 1")); |
| | | Boolean flag = deviceService.openLock(locks); |
| | | if(!flag){ |
| | | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"开锁失败"); |
| | | } |
| | | //存储骑行记录 |
| | | MemberRides memberRides = new MemberRides(); |
| | | memberRides.setIsdeleted(Constants.ZERO); |
| | | memberRides.setMemberId(memberId); |
| | | memberRides.setCreateDate(new Date()); |
| | | memberRides.setRentSiteId(locks.getSiteId()); |
| | | memberRides.setRentLockId(locks.getId()); |
| | | memberRides.setStatus(Constants.MEMBER_RIDES_STATUS.LOCKING.getKey()); |
| | | memberRidesMapper.insert(memberRides); |
| | | |
| | | MemberRidesDetailResponse memberRidesDetailResponse = new MemberRidesDetailResponse(); |
| | | BeanUtils.copyProperties(memberRides,memberRidesDetailResponse); |
| | | return memberRidesDetailResponse; |
| | | |
| | | } |
| | | |
| | | @Override |
| | | public MemberRidesDetailResponse refreshLock(String id){ |
| | | MemberRides memberRides = memberRidesMapper.selectById(id); |
| | | if(Objects.isNull(memberRides)){ |
| | | throw new BusinessException(ResponseStatus.DATA_EMPTY); |
| | | } |
| | | MemberRidesDetailResponse memberRidesDetailResponse = new MemberRidesDetailResponse(); |
| | | BeanUtils.copyProperties(memberRides,memberRidesDetailResponse); |
| | | return memberRidesDetailResponse; |
| | | |
| | | } |
| | | } |