【8.0】【sys】更新获取当前登录用户的远程服务提供

pull/57/head
fengshuonan 2023-08-07 21:23:55 +08:00
parent 3f3fd9061f
commit 39b29ec15e
2 changed files with 73 additions and 1 deletions

View File

@ -31,7 +31,12 @@ public enum UserExceptionEnum implements AbstractExceptionEnum {
/**
* 线
*/
KICK_OFF_ERROR(RuleConstants.USER_OPERATION_ERROR_TYPE_CODE + "10004", "无法操作,只有超级管理员可以踢下线用户");
KICK_OFF_ERROR(RuleConstants.USER_OPERATION_ERROR_TYPE_CODE + "10004", "无法操作,只有超级管理员可以踢下线用户"),
/**
* token
*/
TOKEN_EMPTY_ERROR(RuleConstants.USER_OPERATION_ERROR_TYPE_CODE + "10005", "获取用户失败参数缺失用户token");
/**
*

View File

@ -0,0 +1,67 @@
/*
* Copyright [2020-2030] [https://www.stylefeng.cn]
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* GunsAPACHE LICENSE 2.0使
*
* 1.LICENSE
* 2.Guns
* 3.
* 4. https://gitee.com/stylefeng/guns
* 5. https://gitee.com/stylefeng/guns
* 6.
*/
package cn.stylefeng.roses.kernel.sys.modular.login.provider;
import cn.hutool.core.util.StrUtil;
import cn.stylefeng.roses.kernel.auth.api.SessionManagerApi;
import cn.stylefeng.roses.kernel.auth.api.loginuser.api.LoginUserRemoteApi;
import cn.stylefeng.roses.kernel.auth.api.loginuser.pojo.LoginUserRequest;
import cn.stylefeng.roses.kernel.auth.api.loginuser.pojo.SessionValidateResponse;
import cn.stylefeng.roses.kernel.auth.api.pojo.login.LoginUser;
import cn.stylefeng.roses.kernel.rule.exception.base.ServiceException;
import cn.stylefeng.roses.kernel.sys.api.exception.enums.UserExceptionEnum;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
/**
*
*
* @author fengshuonan
* @since 2023/8/7 21:23
*/
@RestController
public class LoginUserProvider implements LoginUserRemoteApi {
@Resource
private SessionManagerApi sessionManagerApi;
@Override
public LoginUser getLoginUserByToken(@RequestBody LoginUserRequest loginUserRequest) {
if (StrUtil.isBlank(loginUserRequest.getToken())) {
throw new ServiceException(UserExceptionEnum.TOKEN_EMPTY_ERROR);
}
return sessionManagerApi.getSession(loginUserRequest.getToken());
}
@Override
public SessionValidateResponse haveSession(@RequestParam("token") String token) {
boolean validateFlag = sessionManagerApi.haveSession(token);
return new SessionValidateResponse(validateFlag);
}
}