|
@@ -1,20 +1,24 @@
|
|
-package org.dromara.common.satoken.listener;
|
|
|
|
|
|
+package org.dromara.web.listener;
|
|
|
|
|
|
import cn.dev33.satoken.config.SaTokenConfig;
|
|
import cn.dev33.satoken.config.SaTokenConfig;
|
|
import cn.dev33.satoken.listener.SaTokenListener;
|
|
import cn.dev33.satoken.listener.SaTokenListener;
|
|
import cn.dev33.satoken.stp.SaLoginModel;
|
|
import cn.dev33.satoken.stp.SaLoginModel;
|
|
import cn.hutool.http.useragent.UserAgent;
|
|
import cn.hutool.http.useragent.UserAgent;
|
|
import cn.hutool.http.useragent.UserAgentUtil;
|
|
import cn.hutool.http.useragent.UserAgentUtil;
|
|
|
|
+import lombok.RequiredArgsConstructor;
|
|
|
|
+import lombok.extern.slf4j.Slf4j;
|
|
import org.dromara.common.core.constant.CacheConstants;
|
|
import org.dromara.common.core.constant.CacheConstants;
|
|
|
|
+import org.dromara.common.core.constant.Constants;
|
|
import org.dromara.common.core.domain.dto.UserOnlineDTO;
|
|
import org.dromara.common.core.domain.dto.UserOnlineDTO;
|
|
import org.dromara.common.core.domain.model.LoginUser;
|
|
import org.dromara.common.core.domain.model.LoginUser;
|
|
-import org.dromara.common.core.enums.UserType;
|
|
|
|
|
|
+import org.dromara.common.core.utils.MessageUtils;
|
|
|
|
+import org.dromara.common.core.utils.ServletUtils;
|
|
|
|
+import org.dromara.common.core.utils.SpringUtils;
|
|
|
|
+import org.dromara.common.core.utils.ip.AddressUtils;
|
|
|
|
+import org.dromara.common.log.event.LogininforEvent;
|
|
import org.dromara.common.redis.utils.RedisUtils;
|
|
import org.dromara.common.redis.utils.RedisUtils;
|
|
import org.dromara.common.satoken.utils.LoginHelper;
|
|
import org.dromara.common.satoken.utils.LoginHelper;
|
|
-import org.dromara.common.core.utils.ip.AddressUtils;
|
|
|
|
-import org.dromara.common.core.utils.ServletUtils;
|
|
|
|
-import lombok.RequiredArgsConstructor;
|
|
|
|
-import lombok.extern.slf4j.Slf4j;
|
|
|
|
|
|
+import org.dromara.web.service.SysLoginService;
|
|
import org.springframework.stereotype.Component;
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
import java.time.Duration;
|
|
import java.time.Duration;
|
|
@@ -30,37 +34,43 @@ import java.time.Duration;
|
|
public class UserActionListener implements SaTokenListener {
|
|
public class UserActionListener implements SaTokenListener {
|
|
|
|
|
|
private final SaTokenConfig tokenConfig;
|
|
private final SaTokenConfig tokenConfig;
|
|
|
|
+ private final SysLoginService loginService;
|
|
|
|
|
|
/**
|
|
/**
|
|
* 每次登录时触发
|
|
* 每次登录时触发
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
public void doLogin(String loginType, Object loginId, String tokenValue, SaLoginModel loginModel) {
|
|
public void doLogin(String loginType, Object loginId, String tokenValue, SaLoginModel loginModel) {
|
|
- UserType userType = UserType.getUserType(loginId.toString());
|
|
|
|
- if (userType == UserType.SYS_USER) {
|
|
|
|
- UserAgent userAgent = UserAgentUtil.parse(ServletUtils.getRequest().getHeader("User-Agent"));
|
|
|
|
- String ip = ServletUtils.getClientIP();
|
|
|
|
- LoginUser user = LoginHelper.getLoginUser();
|
|
|
|
- UserOnlineDTO dto = new UserOnlineDTO();
|
|
|
|
- dto.setIpaddr(ip);
|
|
|
|
- dto.setLoginLocation(AddressUtils.getRealAddressByIP(ip));
|
|
|
|
- dto.setBrowser(userAgent.getBrowser().getName());
|
|
|
|
- dto.setOs(userAgent.getOs().getName());
|
|
|
|
- dto.setLoginTime(System.currentTimeMillis());
|
|
|
|
- dto.setTokenId(tokenValue);
|
|
|
|
- dto.setUserName(user.getUsername());
|
|
|
|
- dto.setClientKey(user.getClientKey());
|
|
|
|
- dto.setDeviceType(user.getDeviceType());
|
|
|
|
- dto.setDeptName(user.getDeptName());
|
|
|
|
- if(tokenConfig.getTimeout() == -1) {
|
|
|
|
- RedisUtils.setCacheObject(CacheConstants.ONLINE_TOKEN_KEY + tokenValue, dto);
|
|
|
|
- } else {
|
|
|
|
- RedisUtils.setCacheObject(CacheConstants.ONLINE_TOKEN_KEY + tokenValue, dto, Duration.ofSeconds(tokenConfig.getTimeout()));
|
|
|
|
- }
|
|
|
|
- log.info("user doLogin, userId:{}, token:{}", loginId, tokenValue);
|
|
|
|
- } else if (userType == UserType.APP_USER) {
|
|
|
|
- // app端 自行根据业务编写
|
|
|
|
|
|
+ UserAgent userAgent = UserAgentUtil.parse(ServletUtils.getRequest().getHeader("User-Agent"));
|
|
|
|
+ String ip = ServletUtils.getClientIP();
|
|
|
|
+ LoginUser user = LoginHelper.getLoginUser();
|
|
|
|
+ UserOnlineDTO dto = new UserOnlineDTO();
|
|
|
|
+ dto.setIpaddr(ip);
|
|
|
|
+ dto.setLoginLocation(AddressUtils.getRealAddressByIP(ip));
|
|
|
|
+ dto.setBrowser(userAgent.getBrowser().getName());
|
|
|
|
+ dto.setOs(userAgent.getOs().getName());
|
|
|
|
+ dto.setLoginTime(System.currentTimeMillis());
|
|
|
|
+ dto.setTokenId(tokenValue);
|
|
|
|
+ dto.setUserName(user.getUsername());
|
|
|
|
+ dto.setClientKey(user.getClientKey());
|
|
|
|
+ dto.setDeviceType(user.getDeviceType());
|
|
|
|
+ dto.setDeptName(user.getDeptName());
|
|
|
|
+ if(tokenConfig.getTimeout() == -1) {
|
|
|
|
+ RedisUtils.setCacheObject(CacheConstants.ONLINE_TOKEN_KEY + tokenValue, dto);
|
|
|
|
+ } else {
|
|
|
|
+ RedisUtils.setCacheObject(CacheConstants.ONLINE_TOKEN_KEY + tokenValue, dto, Duration.ofSeconds(tokenConfig.getTimeout()));
|
|
}
|
|
}
|
|
|
|
+ // 记录登录日志
|
|
|
|
+ LogininforEvent logininforEvent = new LogininforEvent();
|
|
|
|
+ logininforEvent.setTenantId(user.getTenantId());
|
|
|
|
+ logininforEvent.setUsername(user.getUsername());
|
|
|
|
+ logininforEvent.setStatus(Constants.LOGIN_SUCCESS);
|
|
|
|
+ logininforEvent.setMessage(MessageUtils.message("user.login.success"));
|
|
|
|
+ logininforEvent.setRequest(ServletUtils.getRequest());
|
|
|
|
+ SpringUtils.context().publishEvent(logininforEvent);
|
|
|
|
+ // 更新登录信息
|
|
|
|
+ loginService.recordLoginInfo(user.getUserId(), ip);
|
|
|
|
+ log.info("user doLogin, userId:{}, token:{}", loginId, tokenValue);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|