diff --git a/kernel-s-system/system-api/src/main/java/cn/stylefeng/roses/kernel/sys/api/exception/enums/UserExceptionEnum.java b/kernel-s-system/system-api/src/main/java/cn/stylefeng/roses/kernel/sys/api/exception/enums/UserExceptionEnum.java index 4c37fe432..39cff197f 100644 --- a/kernel-s-system/system-api/src/main/java/cn/stylefeng/roses/kernel/sys/api/exception/enums/UserExceptionEnum.java +++ b/kernel-s-system/system-api/src/main/java/cn/stylefeng/roses/kernel/sys/api/exception/enums/UserExceptionEnum.java @@ -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"); /** * 错误编码 diff --git a/kernel-s-system/system-business-permission/src/main/java/cn/stylefeng/roses/kernel/sys/modular/login/provider/LoginUserProvider.java b/kernel-s-system/system-business-permission/src/main/java/cn/stylefeng/roses/kernel/sys/modular/login/provider/LoginUserProvider.java new file mode 100644 index 000000000..d1f64667e --- /dev/null +++ b/kernel-s-system/system-business-permission/src/main/java/cn/stylefeng/roses/kernel/sys/modular/login/provider/LoginUserProvider.java @@ -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. + * + * Guns采用APACHE 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); + } + +}