From ee09665193c0e91997a9eb880aefbaa5c7342b24 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Mon, 22 Sep 2025 02:12:26 +0800
Subject: [PATCH] 1

---
 ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/UserPolicyServiceImpl.java |   35 +++++++++++++++++++++++++++++------
 1 files changed, 29 insertions(+), 6 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/UserPolicyServiceImpl.java b/ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/UserPolicyServiceImpl.java
index 18b9678..ddc3209 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/UserPolicyServiceImpl.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/UserPolicyServiceImpl.java
@@ -19,6 +19,9 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.text.ParseException;
+import java.time.LocalDate;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
 import java.util.Date;
 import java.util.Random;
 import java.util.concurrent.atomic.AtomicLong;
@@ -40,8 +43,11 @@
         if(ObjectUtil.isEmpty(userAccount)){
             return Result.error("请重新登录,未查询到你的信息!");
         }
-        if(userAccount.getKycStatus() == 0){
+
+        if(userAccount.getKycStatus() == 2){
             return Result.error("请先实名认证");
+        }else if(userAccount.getKycStatus() == 0){
+            return Result.error("实名认证审核中,请耐心等等");
         }
 
         // 验证手机号
@@ -49,16 +55,29 @@
         if(!isPhoneValid){
             return Result.error("手机号格式不正确!");
         }
-        // 验证身份证
-        boolean isIdCardValid = ValidatorUtil.isValidIdCard(dto.getIdCard());
-        if(!isIdCardValid){
-            return Result.error("身份证格式不正确!");
+//        // 验证身份证
+//        boolean isIdCardValid = ValidatorUtil.isValidIdCard(dto.getIdCard());
+//        if(!isIdCardValid){
+//            return Result.error("身份证格式不正确!");
+//        }
+        long count = count(new LambdaQueryWrapper<UserPolicy>()
+                .eq(UserPolicy::getUserId, userAccount.getId())
+                .eq(UserPolicy::getPolicyStatus, UserPolicy.PolicyStatus.ACTIVE)
+                .or()
+                .eq(UserPolicy::getApprovalStatus, 0)
+                .or()
+                .eq(UserPolicy::getApprovalStatus, 1)
+        );
+        if(count > 0){
+            return Result.error("你已申购此保险,请勿重复申购");
         }
         InsuranceProduct insuranceProduct = insuranceProductService.getById(dto.getProductId());
         if(ObjectUtil.isEmpty(insuranceProduct)){
             return Result.error("该产品停止购买或已下架!");
         }
         UserPolicy userPolicy = new UserPolicy();
+        userPolicy.setAccount(userAccount.getAccount());
+        userPolicy.setProductName(insuranceProduct.getProductName());
         userPolicy.setUserId(userAccount.getId());
         userPolicy.setProductId(insuranceProduct.getId());
         userPolicy.setCoverageAmount(insuranceProduct.getCoverageAmount());
@@ -66,7 +85,11 @@
         userPolicy.setTerm(insuranceProduct.getTerm());
         userPolicy.setName(dto.getName());
         userPolicy.setGender(dto.getGender());
-        userPolicy.setBirthDate(DateUtils.parseDate(dto.getBirthDate(),"yyyy-MM-dd HH:mm:ss"));
+
+        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+        LocalDateTime dateTime = LocalDateTime.parse(dto.getBirthDate(), formatter);
+        userPolicy.setBirthDate(dateTime.toLocalDate());
+
         userPolicy.setOccupation(dto.getOccupation());
         userPolicy.setIdCard(dto.getIdCard());
         userPolicy.setPhone(dto.getPhone());

--
Gitblit v1.9.3