From f5ab83dfad01c87828232af8cd18c676e69fd917 Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期三, 21 五月 2025 09:14:11 +0800
Subject: [PATCH] Merge branch 'master' of http://139.186.142.91:10010/r/productDev/dmvisit

---
 server/meeting/meeting_service/src/main/java/com/doumee/service/business/impl/BookingsServiceImpl.java |   46 ++++++++++++++++++++++++++++++++--------------
 1 files changed, 32 insertions(+), 14 deletions(-)

diff --git a/server/meeting/meeting_service/src/main/java/com/doumee/service/business/impl/BookingsServiceImpl.java b/server/meeting/meeting_service/src/main/java/com/doumee/service/business/impl/BookingsServiceImpl.java
index bd6110b..fd048af 100644
--- a/server/meeting/meeting_service/src/main/java/com/doumee/service/business/impl/BookingsServiceImpl.java
+++ b/server/meeting/meeting_service/src/main/java/com/doumee/service/business/impl/BookingsServiceImpl.java
@@ -644,11 +644,11 @@
             s.setSysList(userrelList);
             //浼氳瀹ょ鐞嗗憳
             MPJLambdaWrapper<UserRel> param = new MPJLambdaWrapper<>();
-            urquery.selectAll(UserRel.class);
-            urquery.eq(UserRel::getObjType, MeetConstants.ZERO);
-            urquery.eq(UserRel::getIsdeleted, MeetConstants.ZERO);
-            urquery.eq(UserRel::getObjId, s.getRoomId());
-            List<UserRel> adminList = userRelJoinMapper.selectJoinList(UserRel.class, urquery);
+            param.selectAll(UserRel.class);
+            param.eq(UserRel::getObjType, MeetConstants.ZERO);
+            param.eq(UserRel::getIsdeleted, MeetConstants.ZERO);
+            param.eq(UserRel::getObjId, s.getRoomId());
+            List<UserRel> adminList = userRelJoinMapper.selectJoinList(UserRel.class, param);
             s.setAdminList(adminList);
 
             //鏌ヨ鏄惁鏈夋潈闄�
@@ -674,7 +674,7 @@
         if(Constants.equalsInteger(userInfo.getId(),s.getCreator())  ){
               return 1;
         }
-        if(adminList!=null){
+        if(adminList!=null && userInfo!=null){
             for(UserRel u : adminList){
                 if(Constants.equalsInteger(userInfo.getId(),u.getUserId())  ){
                     return 1;
@@ -1210,8 +1210,20 @@
         if (Objects.isNull(bookings)) {
             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "鏈煡璇㈠埌棰勭害璁板綍");
         }
-        if (!bookings.getCreator().equals(businessOverDTO.getUserId())) {
-            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "闈炰綘鐨勯绾﹁褰�,鏃犳硶杩涜鍙栨秷");
+
+//        LoginUserInfo user =(LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+        //浼氳瀹ょ鐞嗗憳
+        MPJLambdaWrapper<UserRel> param = new MPJLambdaWrapper<>();
+        param.selectAll(UserRel.class);
+        param.eq(UserRel::getObjType, MeetConstants.ZERO);
+        param.eq(UserRel::getIsdeleted, MeetConstants.ZERO);
+        param.eq(UserRel::getObjId, bookings.getRoomId());
+        List<UserRel> adminList = userRelJoinMapper.selectJoinList(UserRel.class, param);
+        Integer hasRole =getHasRoleByParam(bookings,businessOverDTO.getLoginUser(),adminList);
+
+//        if (!bookings.getCreator().equals(businessOverDTO.getUserId())) {
+        if (!Constants.equalsInteger(hasRole,Constants.ONE)) {
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "瀵逛笉璧凤紝鍙湁浼氳瀹ょ鐞嗗憳鍜岀敵璇蜂汉鎵嶈兘杩涜璇ユ搷浣滃摝锛�");
         }
         if (Objects.nonNull(bookings.getStartTimeReal()) && System.currentTimeMillis() > bookings.getStartTimeReal().getTime()) {
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "浼氳宸插紑濮�,鏃犳硶杩涜鍙栨秷");
@@ -1316,21 +1328,24 @@
         for (Rooms rooms:roomList) {
             //鏌ヨ褰撳墠浼氳瀹ゆ槸鍚﹀瓨鍦ㄨ繘琛屼腑鐨勪細璁�
             if(bookingsMapper.selectCount(new QueryWrapper<Bookings>().lambda().eq(Bookings::getIsdeleted,Constants.ZERO)
-                    .eq(Bookings::getStatus,Constants.ZERO).isNotNull(Bookings::getStartTimeReal)
+                    .eq(Bookings::getStatus,Constants.ZERO).eq(Bookings::getRoomId,rooms.getId()).isNotNull(Bookings::getStartTimeReal).
+                    apply(" DATE_FORMAT(NOW(), '%Y-%m-%d') = DATE_FORMAT(START_TIME, '%Y-%m-%d') ")
             )<=Constants.ZERO){
                 //鏍规嵁浼氳瀹よ幏鍙栧彲浠ュ紑鍚殑浼氳璁板綍锛堢涓�鏉¤褰曪級
                 Bookings bookings = bookingsMapper.selectOne(new QueryWrapper<Bookings>().lambda()
                         .eq(Bookings::getIsdeleted,Constants.ZERO)
                         .eq(Bookings::getStatus,Constants.ZERO)
                         .eq(Bookings::getRoomId,rooms.getId())
-                        .apply(" now() > START_TIME and now < END_TIME ")
+                        .apply(" now() > START_TIME and now() < END_TIME ")
                         .isNull(Bookings::getStartTimeReal)
                         .orderByAsc(Bookings::getStartTime)
                         .last(" limit 1 ")
                 );
-                bookings.setStartTimeReal(new Date());
-                bookings.setEditDate(new Date());
-                bookingsMapper.updateById(bookings);
+                if(Objects.nonNull(bookings)){
+                    bookings.setStartTimeReal(new Date());
+                    bookings.setEditDate(bookings.getStartTimeReal());
+                    bookingsMapper.updateById(bookings);
+                }
             }
         }
     }
@@ -1466,7 +1481,10 @@
                  .eq(Bookings::getIsdeleted, MeetConstants.ZERO)
                  .eq(Bookings::getStatus, MeetConstants.ZERO)
                  .eq(Rooms::getId, rooms.getId())
-                 .apply("to_days(t.start_time) = to_days(now()) and t.end_time > now()")//瀛愭煡璇㈠綋澶╃殑
+                 .apply(" (  " +
+                         " to_days(t.start_time) = to_days(now()) " +
+                         " and ( t.START_TIME_REAL is not null or ( t.end_time > now()  and  t.START_TIME_REAL is  null ) ) " +
+                         " ) ")//瀛愭煡璇㈠綋澶╃殑
                  .orderByAsc(Bookings::getStartTime);
         Integer minute =getNearStartMinut();
         List<Bookings> meetingList =bookingsMapper.selectJoinList(Bookings.class,queryWrapper);

--
Gitblit v1.9.3