TokensController.java 2.7 KB
Newer Older
1 2
package com.central.oauth.controller;

zlt2000's avatar
zlt2000 已提交
3
import com.central.common.constant.SecurityConstants;
4
import com.central.common.model.PageResult;
zlt2000's avatar
zlt2000 已提交
5
import com.central.common.model.Result;
6 7
import com.central.oauth.model.TokenVo;
import com.central.oauth.service.ITokensService;
zlt2000's avatar
zlt2000 已提交
8
import com.central.oauth2.common.util.AuthUtils;
9 10
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
zlt2000's avatar
zlt2000 已提交
11 12 13
import lombok.extern.slf4j.Slf4j;
import org.springframework.core.io.ClassPathResource;
import org.springframework.security.authentication.BadCredentialsException;
zlt2000's avatar
zlt2000 已提交
14
import org.springframework.security.core.AuthenticationException;
zlt2000's avatar
zlt2000 已提交
15 16 17
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.oauth2.provider.ClientDetails;
import org.springframework.security.oauth2.provider.ClientDetailsService;
18 19
import org.springframework.web.bind.annotation.*;

zlt2000's avatar
zlt2000 已提交
20 21 22 23 24
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
25
import java.util.Map;
zlt2000's avatar
zlt2000 已提交
26
import java.util.stream.Collectors;
27 28 29 30 31 32 33

/**
 * token管理接口
 *
 * @author zlt
 */
@Api(tags = "Token管理")
zlt2000's avatar
zlt2000 已提交
34
@Slf4j
35 36 37
@RestController
@RequestMapping("/tokens")
public class TokensController {
zlt2000's avatar
zlt2000 已提交
38
    @Resource
39 40
    private ITokensService tokensService;

zlt2000's avatar
zlt2000 已提交
41 42 43 44 45 46
    @Resource
    private ClientDetailsService clientDetailsService;

    @Resource
    private PasswordEncoder passwordEncoder;

zlt2000's avatar
zlt2000 已提交
47
    @GetMapping("")
48
    @ApiOperation(value = "token列表")
zlt2000's avatar
zlt2000 已提交
49 50
    public PageResult<TokenVo> list(@RequestParam Map<String, Object> params, String tenantId) {
        return tokensService.listTokens(params, tenantId);
51
    }
zlt2000's avatar
zlt2000 已提交
52 53 54 55

    @GetMapping("/key")
    @ApiOperation(value = "获取jwt密钥")
    public Result<String> key(HttpServletRequest request) {
zlt2000's avatar
zlt2000 已提交
56 57 58 59 60 61 62 63
        try {
            String[] clientArr = AuthUtils.extractClient(request);
            ClientDetails clientDetails = clientDetailsService.loadClientByClientId(clientArr[0]);
            if (clientDetails == null || !passwordEncoder.matches(clientArr[1], clientDetails.getClientSecret())) {
                throw new BadCredentialsException("应用ID或密码错误");
            }
        } catch (AuthenticationException ae) {
            return Result.failed(ae.getMessage());
zlt2000's avatar
zlt2000 已提交
64 65 66 67 68 69 70 71 72
        }
        org.springframework.core.io.Resource res = new ClassPathResource(SecurityConstants.RSA_PUBLIC_KEY);
        try (BufferedReader br = new BufferedReader(new InputStreamReader(res.getInputStream()))) {
            return Result.succeed(br.lines().collect(Collectors.joining("\n")));
        } catch (IOException ioe) {
            log.error("key error", ioe);
            return Result.failed(ioe.getMessage());
        }
    }
73
}