From 4e334f94828bf9842649cfd91399b6ee00fbeef0 Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期三, 16 七月 2025 11:54:01 +0800
Subject: [PATCH] 111

---
 server/services/src/main/java/com/doumee/service/business/impl/IdentityInfoServiceImpl.java |   22 ++++++++++++++++++++--
 1 files changed, 20 insertions(+), 2 deletions(-)

diff --git a/server/services/src/main/java/com/doumee/service/business/impl/IdentityInfoServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/IdentityInfoServiceImpl.java
index a9f3b7f..34ae3da 100644
--- a/server/services/src/main/java/com/doumee/service/business/impl/IdentityInfoServiceImpl.java
+++ b/server/services/src/main/java/com/doumee/service/business/impl/IdentityInfoServiceImpl.java
@@ -52,6 +52,7 @@
     private SystemDictDataBiz systemDictDataBiz;
 
     @Override
+    @Transactional(rollbackFor = {BusinessException.class,Exception.class})
     public Integer create(IdentityInfo identityInfo) {
         if(Objects.isNull(identityInfo)
         || Objects.isNull(identityInfo.getType())
@@ -71,13 +72,22 @@
             throw new BusinessException(ResponseStatus.BAD_REQUEST);
         }
         //鏌ヨ鐢ㄦ埛鏄惁宸插瓨鍦ㄥ綋鍓嶈韩浠�
-        if(identityInfoMapper.selectCount(new QueryWrapper<IdentityInfo>().lambda().eq(IdentityInfo::getMemberId,identityInfo.getMemberId())
+        if(identityInfoMapper.selectCount(new QueryWrapper<IdentityInfo>().lambda().eq(IdentityInfo::getDeleted,Constants.ZERO).eq(IdentityInfo::getMemberId,identityInfo.getMemberId())
                 .eq(IdentityInfo::getType,identityInfo.getType()))>Constants.ZERO){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"宸插瓨鍦ㄨ韬唤璇峰埛鏂版煡鐪嬶紒");
         };
+        identityInfo.setDeleted(Constants.ZERO);
         identityInfo.setCreateTime(new Date());
-        identityInfo.setAuditStatus(Constants.ZERO);
+        identityInfo.setUpdateTime(identityInfo.getCreateTime());
+        identityInfo.setAuditStatus(Constants.ONE);
         identityInfoMapper.insert(identityInfo);
+
+        memberMapper.update(new UpdateWrapper<Member>().lambda()
+                .set(Constants.equalsInteger(identityInfo.getType(),Constants.ZERO),Member::getWorkerIdentity,Constants.ONE)
+                .set(Constants.equalsInteger(identityInfo.getType(),Constants.ONE),Member::getDriverIdentity,Constants.ONE)
+                .set(Constants.equalsInteger(identityInfo.getType(),Constants.TWO),Member::getChefIdentity,Constants.ONE)
+                .eq(Member::getId,identityInfo.getMemberId()));
+
         return identityInfo.getId();
     }
 
@@ -101,6 +111,7 @@
     }
 
     @Override
+    @Transactional(rollbackFor = {BusinessException.class,Exception.class})
     public void updateById(IdentityInfo identityInfo) {
         if(Objects.isNull(identityInfo)
                 || Objects.isNull(identityInfo.getId())
@@ -131,11 +142,18 @@
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"褰撳墠鐘舵�佹棤娉曡繘琛岃鎿嶄綔");
         }
         identityInfo.setUpdateTime(new Date());
+        identityInfo.setAuditStatus(Constants.ONE);
         identityInfoMapper.updateById(identityInfo);
+        memberMapper.update(new UpdateWrapper<Member>().lambda()
+                .set(Constants.equalsInteger(identityInfo.getType(),Constants.ZERO),Member::getWorkerIdentity,Constants.ONE)
+                .set(Constants.equalsInteger(identityInfo.getType(),Constants.ONE),Member::getDriverIdentity,Constants.ONE)
+                .set(Constants.equalsInteger(identityInfo.getType(),Constants.TWO),Member::getChefIdentity,Constants.ONE)
+                .eq(Member::getId,identityInfo.getMemberId()));
     }
 
 
     @Override
+    @Transactional(rollbackFor = {BusinessException.class,Exception.class})
     public void updateLocation(IdentityInfo identityInfo) {
         if(Objects.isNull(identityInfo)
                 || Objects.isNull(identityInfo.getId())

--
Gitblit v1.9.3