From 99f0b2a145ec1615143a1108db2b581c4723ab93 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期二, 25 五月 2021 16:06:50 +0800
Subject: [PATCH] 订单与VIP修改

---
 service-vip/src/main/java/com/ks/vip/service/remote/VipCenterServiceImpl.java |   93 +++++++++++++++++++++++++++++-----------------
 1 files changed, 59 insertions(+), 34 deletions(-)

diff --git a/service-vip/src/main/java/com/ks/vip/service/remote/VipCenterServiceImpl.java b/service-vip/src/main/java/com/ks/vip/service/remote/VipCenterServiceImpl.java
index e88f5c1..f3bfce9 100644
--- a/service-vip/src/main/java/com/ks/vip/service/remote/VipCenterServiceImpl.java
+++ b/service-vip/src/main/java/com/ks/vip/service/remote/VipCenterServiceImpl.java
@@ -2,8 +2,10 @@
 
 
 import com.ks.vip.mapper.VipCenterMapper;
+import com.ks.vip.mapper.VipCenterRecordMapper;
 import com.ks.vip.mapper.VipComboMapper;
 import com.ks.vip.pojo.DO.*;
+import com.ks.vip.pojo.Enums.VIPEnum;
 import com.ks.vip.query.VipCenterQuery;
 import com.ks.vip.query.VipComboQuery;
 import com.ks.vip.service.*;
@@ -30,15 +32,17 @@
     @Resource
     private VipGradePotenceService vipGradePotenceService;
 
+    @Resource
+    private VipCenterRecordMapper vipCenterRecordMapper;
 
 
     @Override
-    public void insertSelective(VipCenter t){
+    public void insertSelective(VipCenter t) {
         vipCenterMapper.insertSelective(t);
     }
 
     @Override
-    public void updateByPrimaryKeySelective(VipCenter t){
+    public void updateByPrimaryKeySelective(VipCenter t) {
         vipCenterMapper.updateByPrimaryKeySelective(t);
     }
 
@@ -75,18 +79,19 @@
 
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public void saveVipCenter(String uid, Long gradeId, Integer validDays, Long orderId) {
+    public void saveVipCenter(String uid, Long gradeId, Integer validHours, Long orderId) {
         VipCenterRecord record = new VipCenterRecord();
 
         VipCenter vipCenter = vipCenterMapper.selectForUpdate(uid);
-        if (vipCenter == null)  {
+        if (vipCenter == null) {
+            vipCenter=new VipCenter();
             Date startTime = new Date();
-            Date endTime = DateUtil.plusDayDate(validDays, startTime);
+            Date endTime = new Date(startTime.getTime() + 1000 * 60 * 60L * validHours);
 
             vipCenter.setUid(uid);
             vipCenter.setGradeId(gradeId);
             vipCenter.setStartTime(startTime);
-            vipCenter.setEndTime(DateUtil.plusDayDate(validDays, new Date()));
+            vipCenter.setEndTime(endTime);
             vipCenter.setCreateTime(new Date());
             vipCenterMapper.insertSelective(vipCenter);
 
@@ -100,10 +105,12 @@
             long nowTime = java.lang.System.currentTimeMillis();
             if (gradeId.longValue() == oldGradeId.longValue() && vipCenter.getEndTime().getTime() > nowTime) {
                 // 涓婃浼氬憳杩樻湭宸茬粨鏉�
-                endTime = DateUtil.plusDayDate(validDays, vipCenter.getEndTime());
+                record.setStartTime(endTime);
+                endTime = new Date(vipCenter.getEndTime().getTime() + 1000 * 60 * 60L * validHours);
             } else {
                 startTime = new Date();
-                endTime = DateUtil.plusDayDate(validDays, startTime);
+                record.setStartTime(startTime);
+                endTime = new Date(startTime.getTime() + 1000 * 60 * 60L * validHours);
             }
             vipCenter.setStartTime(startTime);
             vipCenter.setEndTime(endTime);
@@ -111,7 +118,6 @@
             vipCenter.setUpdateTime(new Date());
             vipCenterMapper.updateByPrimaryKeySelective(vipCenter);
 
-            record.setStartTime(new Date());
             record.setEndTime(endTime);
         }
 
@@ -119,46 +125,65 @@
         record.setUid(uid);
         record.setGradeId(gradeId);
         record.setCreateTime(new Date());
+        record.setState(1);
         vipCenterRecordService.insertSelective(record);
     }
 
 
     @Override
-    public boolean verifyVIP(String uid) {
-        VipCenter vipCenter = vipCenterMapper.getByUid(uid);
-        if (vipCenter == null) {
-            return false;
-        }
-        // 楠岃瘉浼氬憳鏄惁鏈夋晥
-        long nowTime = java.lang.System.currentTimeMillis();
-        if (vipCenter.getStartTime().getTime() <= nowTime && vipCenter.getEndTime().getTime() >= nowTime) {
-            return true;
-        }
-        return false;
-    }
-
-    @Override
     public VipGradePotence getVipPotence(String uid) {
+        VipGradePotence potence = null;
         VipCenter vipCenter = vipCenterMapper.getByUid(uid);
-        if (vipCenter == null || vipCenter.getGradeId() == null) {
-            return null;
+        if (vipCenter != null || vipCenter.getGradeId() != null) {
+            long nowTime = java.lang.System.currentTimeMillis();
+            if (vipCenter.getStartTime().getTime() <= nowTime && vipCenter.getEndTime().getTime() >= nowTime) {
+                potence = vipGradePotenceService.getPotenceByGradeId(vipCenter.getGradeId());
+            }
         }
-
-        long nowTime = java.lang.System.currentTimeMillis();
-        if (vipCenter.getStartTime().getTime() <= nowTime && vipCenter.getEndTime().getTime() >= nowTime) {
-            return vipGradePotenceService.selectByPrimaryKey(vipCenter.getGradeId());
+        if (potence == null) {
+            potence = vipGradePotenceService.getDefaultGradePotence();
         }
-        return null;
+        return potence;
     }
 
 
     @Override
     public VipGrade getVipGrade(String uid) {
+        VipGrade vipGrade = null;
         VipCenter vipCenter = vipCenterMapper.getByUid(uid);
-        if (vipCenter == null || vipCenter.getGradeId() == null) {
-            return null;
+        if (vipCenter != null && vipCenter.getGradeId() != null) {
+            long nowTime = java.lang.System.currentTimeMillis();
+            if (vipCenter.getStartTime().getTime() <= nowTime && vipCenter.getEndTime().getTime() >= nowTime) {
+                vipGrade = vipGradeService.selectByPrimaryKey(vipCenter.getGradeId());
+            }
         }
-        return vipGradeService.selectByPrimaryKey(vipCenter.getGradeId());
+        if (vipGrade == null) {
+            vipGradeService.getDefaultGrade();
+        }
+        return vipGrade;
     }
 
-}
+    @Override
+    public VIPEnum getVIPEnumByUid(String uid) {
+        VipGrade vipGrade = getVipGrade(uid);
+        if (vipGrade != null) {
+            return vipGrade.getIdentity();
+        } else {
+            return null;
+        }
+    }
+
+    @Override
+    public VIPEnum getVIPEnumByUid(String uid, Date date) {
+        VipCenterRecordMapper.DaoQuery daoQuery = new VipCenterRecordMapper.DaoQuery();
+        daoQuery.uid = uid;
+        daoQuery.date = date;
+        daoQuery.start = 0;
+        daoQuery.count = 1;
+        List<VipCenterRecord> list = vipCenterRecordMapper.list(daoQuery);
+        if (list == null || list.size() == 0) {
+            return vipGradeService.getDefaultGrade().getIdentity();
+        }
+        return vipGradeService.selectByPrimaryKey(list.get(0).getGradeId()).getIdentity();
+    }
+}
\ No newline at end of file

--
Gitblit v1.8.0