74 lines
3.0 KiB
Java
74 lines
3.0 KiB
Java
/**
|
|
* Copyright (c) 2018-2028, Chill Zhuang 庄骞 (smallchill@163.com).
|
|
* <p>
|
|
* 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
|
|
* <p>
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
* <p>
|
|
* 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.
|
|
*/
|
|
package org.springblade.auth.controller;
|
|
|
|
import io.swagger.annotations.Api;
|
|
import io.swagger.annotations.ApiOperation;
|
|
import io.swagger.annotations.ApiParam;
|
|
import lombok.AllArgsConstructor;
|
|
import org.springblade.auth.granter.ITokenGranter;
|
|
import org.springblade.auth.granter.TokenGranterBuilder;
|
|
import org.springblade.auth.granter.TokenParameter;
|
|
import org.springblade.auth.utils.TokenUtil;
|
|
import org.springblade.core.secure.AuthInfo;
|
|
import org.springblade.core.tool.api.R;
|
|
import org.springblade.core.tool.utils.Func;
|
|
import org.springblade.core.tool.utils.WebUtil;
|
|
import org.springblade.system.user.entity.UserInfo;
|
|
import org.springframework.web.bind.annotation.PostMapping;
|
|
import org.springframework.web.bind.annotation.RequestParam;
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
/**
|
|
* 认证模块
|
|
*
|
|
* @author Chill
|
|
*/
|
|
@RestController
|
|
@AllArgsConstructor
|
|
@Api(value = "用户授权认证", tags = "授权接口")
|
|
public class AuthController {
|
|
|
|
@PostMapping("token")
|
|
@ApiOperation(value = "获取认证token", notes = "传入租户ID:tenantId,账号:account,密码:password")
|
|
public R<AuthInfo> token(@ApiParam(value = "授权类型", required = true) @RequestParam(defaultValue = "password", required = false) String grantType,
|
|
@ApiParam(value = "刷新令牌") @RequestParam(required = false) String refreshToken,
|
|
@ApiParam(value = "租户ID", required = true) @RequestParam(defaultValue = "000000", required = false) String tenantId,
|
|
@ApiParam(value = "账号") @RequestParam(required = false) String account,
|
|
@ApiParam(value = "密码") @RequestParam(required = false) String password) {
|
|
|
|
String userType = Func.toStr(WebUtil.getRequest().getHeader(TokenUtil.USER_TYPE_HEADER_KEY), TokenUtil.DEFAULT_USER_TYPE);
|
|
|
|
TokenParameter tokenParameter = new TokenParameter();
|
|
tokenParameter.getArgs().set("tenantId", tenantId)
|
|
.set("account", account)
|
|
.set("password", password)
|
|
.set("grantType", grantType)
|
|
.set("refreshToken", refreshToken)
|
|
.set("userType", userType);
|
|
|
|
ITokenGranter granter = TokenGranterBuilder.getGranter(grantType);
|
|
UserInfo userInfo = granter.grant(tokenParameter);
|
|
|
|
if (userInfo == null || userInfo.getUser() == null || userInfo.getUser().getId() == null) {
|
|
return R.fail(TokenUtil.USER_NOT_FOUND);
|
|
}
|
|
|
|
return R.data(TokenUtil.createAuthInfo(userInfo));
|
|
}
|
|
|
|
}
|