Prechádzať zdrojové kódy

新增用户过期时间

车车 2 mesiacov pred
rodič
commit
19fa71f05f

+ 4 - 0
yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/user/vo/user/UserPageReqVO.java

@@ -50,4 +50,8 @@ public class UserPageReqVO extends PageParam {
     @Schema(description = "部门code,如果拿到code再拿到deptid进行查询", example = "1")
     private String code;
 
+    @Schema(description = "过期时间")
+    @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
+    private LocalDateTime expireTime;
+
 }

+ 7 - 0
yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/user/vo/user/UserRespVO.java

@@ -7,10 +7,13 @@ import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
 import com.alibaba.excel.annotation.ExcelProperty;
 import io.swagger.v3.oas.annotations.media.Schema;
 import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
 
 import java.time.LocalDateTime;
 import java.util.Set;
 
+import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
+
 @Schema(description = "管理后台 - 用户信息 Response VO")
 @Data
 @ExcelIgnoreUnannotated
@@ -78,4 +81,8 @@ public class UserRespVO{
     @Schema(description = "岗位编号数组", example = "1")
     private Set<Long> workstationIds;
 
+    @Schema(description = "过期时间")
+    @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
+    private LocalDateTime expireTime;
+
 }

+ 6 - 0
yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/user/vo/user/UserSaveReqVO.java

@@ -5,6 +5,7 @@ import cn.iocoder.yudao.framework.common.validation.Mobile;
 import cn.iocoder.yudao.module.system.framework.operatelog.core.DeptParseFunction;
 import cn.iocoder.yudao.module.system.framework.operatelog.core.PostParseFunction;
 import cn.iocoder.yudao.module.system.framework.operatelog.core.SexParseFunction;
+import com.fasterxml.jackson.annotation.JsonFormat;
 import com.fasterxml.jackson.annotation.JsonIgnore;
 import com.mzt.logapi.starter.annotation.DiffLogField;
 import io.swagger.v3.oas.annotations.media.Schema;
@@ -12,6 +13,7 @@ import jakarta.validation.constraints.*;
 import lombok.Data;
 import org.hibernate.validator.constraints.Length;
 
+import java.util.Date;
 import java.util.Set;
 
 @Schema(description = "管理后台 - 用户创建/修改 Request VO")
@@ -67,6 +69,10 @@ public class UserSaveReqVO {
     @DiffLogField(name = "用户头像")
     private String avatar;
 
+    @Schema(description = "过期时间", example = "2099-12-31 23:59:59")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date expireTime;
+
     // ========== 仅【创建】时,需要传递的字段 ==========
 
     @Schema(description = "密码", requiredMode = Schema.RequiredMode.REQUIRED, example = "123456")

+ 4 - 0
yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/dataobject/user/AdminUserDO.java

@@ -106,5 +106,9 @@ public class AdminUserDO extends TenantBaseDO {
      * 是否测试(0-否 1-是)
      */
     private Integer isTest;
+    /**
+     * 过期时间
+     */
+    private LocalDateTime expireTime;
 
 }

+ 2 - 0
yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/enums/ErrorCodeConstants.java

@@ -12,6 +12,8 @@ public interface ErrorCodeConstants {
     // ========== AUTH 模块 1-002-000-000 ==========
     ErrorCode AUTH_LOGIN_BAD_CREDENTIALS = new ErrorCode(1_002_000_000, "登录失败,账号密码不正确");
     ErrorCode AUTH_LOGIN_USER_DISABLED = new ErrorCode(1_002_000_001, "登录失败,账号被禁用");
+
+    ErrorCode AUTH_LOGIN_USER_EXPIRED = new ErrorCode(1_002_000_002, "登录失败,账号已过期");
     ErrorCode AUTH_LOGIN_CAPTCHA_CODE_ERROR = new ErrorCode(1_002_000_004, "验证码不正确,原因:{}");
     ErrorCode AUTH_THIRD_LOGIN_NOT_BIND = new ErrorCode(1_002_000_005, "未绑定账号,需要进行绑定");
     ErrorCode AUTH_MOBILE_NOT_EXISTS = new ErrorCode(1_002_000_007, "手机号不存在");

+ 1 - 0
yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/enums/logger/LoginResultEnum.java

@@ -13,6 +13,7 @@ public enum LoginResultEnum {
     SUCCESS(0), // 成功
     BAD_CREDENTIALS(10), // 账号或密码不正确
     USER_DISABLED(20), // 用户被禁用
+    USER_EXPIRED(21), // 用户账号过期
     CAPTCHA_NOT_FOUND(30), // 图片验证码不存在
     CAPTCHA_CODE_ERROR(31), // 图片验证码不正确
 

+ 26 - 0
yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/auth/AdminAuthServiceImpl.java

@@ -54,6 +54,7 @@ import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.multipart.MultipartFile;
 
 import java.io.IOException;
+import java.time.LocalDateTime;
 import java.util.HashSet;
 import java.util.List;
 import java.util.Objects;
@@ -126,11 +127,30 @@ public class AdminAuthServiceImpl implements AdminAuthService {
             createLoginLog(user.getId(), username, logTypeEnum, LoginResultEnum.USER_DISABLED);
             throw exception(AUTH_LOGIN_USER_DISABLED);
         }
+        // 校验是否过期
+        if (isExpired(user.getExpireTime())) {
+            createLoginLog(user.getId(), username, logTypeEnum, LoginResultEnum.USER_EXPIRED);
+            throw exception(AUTH_LOGIN_USER_EXPIRED);
+        }
         // 新增登录校验规则
         // addAuthenticate(user, username);
         return user;
     }
 
+    public boolean isExpired(LocalDateTime expireTime) {
+        // 1. 处理null场景:根据业务需求调整(比如null表示永不过期)
+        if (expireTime == null) {
+            return true; // 若null需视为过期,可改为return true
+        }
+
+        // 2. 获取当前系统时间(默认使用系统默认时区)
+        LocalDateTime now = LocalDateTime.now();
+
+        // 3. 核心对比:当前时间 > 过期时间 → 已过期
+        // isAfter():判断当前时间是否在过期时间之后
+        return now.isAfter(expireTime);
+    }
+
     /*public void addAuthenticate(AdminUserDO user, String username) {
         // 检查用户在该模块是否是黑名单
         String headerModule = ServletUtils.getRequest().getHeader("Module");
@@ -414,6 +434,12 @@ public class AdminAuthServiceImpl implements AdminAuthService {
             createLoginLog(user.getId(), username, logTypeEnum, LoginResultEnum.USER_DISABLED);
             throw exception(AUTH_LOGIN_USER_DISABLED);
         }
+        // 校验是否过期
+        if (isExpired(user.getExpireTime())) {
+            createLoginLog(user.getId(), username, logTypeEnum, LoginResultEnum.USER_EXPIRED);
+            throw exception(AUTH_LOGIN_USER_EXPIRED);
+        }
+
         // 新增登录校验规则
         // addAuthenticate(user, username);
         return user;