shikeying
2024-01-11 3b67e947e36133e2a40eb2737b15ea375e157ea0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
package com.walker.web;
 
import java.io.Serializable;
import java.util.List;
 
/**
 * 用户认证后的存储信息,这里定义规范,由业务实现。
 * <pre>
 *     1)单应用集成 walker-web-security 时需要实现。
 *     2)网关微服务应用 过滤器拦截并返回该对象实现。
 * </pre>
 */
public interface UserPrincipal<T> extends Serializable {
 
    /**
     * 返回用户唯一编号,业务对应用户数据库中的id
     * @return
     */
    String getId();
 
    /**
     * 返回用户名称,姓名或昵称
     * @return
     */
    String getUserName();
 
    /**
     * 返回用户加密后的密码(MD5加密值)
     * @return
     */
    String getPassword();
 
    /**
     * 用户当前是否可用
     * @return
     */
    boolean isEnabled();
 
    /**
     * 判断token是否失效
     * @param token 系统生成的唯一token
     * @return
     */
    boolean isTokenExpired(String token);
 
    /**
     * 用户是否被锁定
     * @return
     */
    boolean isAccountLocked();
 
    /**
     * 验证MD5密码是否正确
     * @param encryption
     * @return
     */
    boolean validateMd5Password(String encryption);
 
    /**
     * 返回用户实际对象,通常是业务提供的用户信息。
     * @return
     */
    T getUserInfo();
 
    /**
     * 上次登录时间,格式: 20221029113601
     * @return
     */
    long getLastLoginTime();
 
    /**
     * 上次登录类型
     * @return
     */
    LoginType getLastLoginType();
 
    /**
     * 返回用户所属角色ID集合。为若依前端适配添加。
     * @return
     * @date 2022-11-11
     */
    List<String> getRoleIdList();
 
    public void setRoleIdList(List<String> roleIdList);
 
    /**
     * 是否超级管理员
     * @return
     * @date 2022-12-21
     */
    boolean isSupervisor();
 
    /**
     * 返回用户对应某个功能的数据权限标识。
     * @param menuId
     * @return
     * @date 2022-12-21
     */
    String getDataScope(String menuId);
}