AuthGoogleRequest.java 3.5 KB
Newer Older
1 2
package me.zhyd.oauth.request;

3
import cn.hutool.http.HttpRequest;
4 5 6
import cn.hutool.http.HttpResponse;
import com.alibaba.fastjson.JSONObject;
import me.zhyd.oauth.config.AuthConfig;
7
import me.zhyd.oauth.config.AuthSource;
智布道's avatar
智布道 已提交
8
import me.zhyd.oauth.enums.AuthUserGender;
9
import me.zhyd.oauth.exception.AuthException;
10
import me.zhyd.oauth.model.AuthCallback;
11 12
import me.zhyd.oauth.model.AuthToken;
import me.zhyd.oauth.model.AuthUser;
不合群的混子's avatar
不合群的混子 已提交
13
import me.zhyd.oauth.utils.UrlBuilder;
14 15 16 17 18

/**
 * Google登录
 *
 * @author yangkai.shen (https://xkcoding.com)
智布道's avatar
智布道 已提交
19
 * @since 1.3.0
20
 */
智布道's avatar
智布道 已提交
21
public class AuthGoogleRequest extends AuthDefaultRequest {
22 23

    public AuthGoogleRequest(AuthConfig config) {
不合群的混子's avatar
不合群的混子 已提交
24
        super(config, AuthSource.GOOGLE);
25 26 27
    }

    @Override
28
    protected AuthToken getAccessToken(AuthCallback authCallback) {
不合群的混子's avatar
不合群的混子 已提交
29
        HttpResponse response = doPostAuthorizationCode(authCallback.getCode());
智布道's avatar
智布道 已提交
30
        JSONObject accessTokenObject = JSONObject.parseObject(response.body());
智布道's avatar
智布道 已提交
31
        this.checkResponse(accessTokenObject);
32
        return AuthToken.builder()
不合群的混子's avatar
不合群的混子 已提交
33 34 35 36 37 38
            .accessToken(accessTokenObject.getString("access_token"))
            .expireIn(accessTokenObject.getIntValue("expires_in"))
            .scope(accessTokenObject.getString("scope"))
            .tokenType(accessTokenObject.getString("token_type"))
            .idToken(accessTokenObject.getString("id_token"))
            .build();
39 40 41 42
    }

    @Override
    protected AuthUser getUserInfo(AuthToken authToken) {
43 44 45
        HttpResponse response = HttpRequest.post(userInfoUrl(authToken))
            .header("Authorization", "Bearer " + authToken.getAccessToken())
            .execute();
46 47
        String userInfo = response.body();
        JSONObject object = JSONObject.parseObject(userInfo);
智布道's avatar
智布道 已提交
48
        this.checkResponse(object);
49
        return AuthUser.builder()
不合群的混子's avatar
不合群的混子 已提交
50
            .uuid(object.getString("sub"))
51
            .username(object.getString("email"))
不合群的混子's avatar
不合群的混子 已提交
52 53 54 55 56 57
            .avatar(object.getString("picture"))
            .nickname(object.getString("name"))
            .location(object.getString("locale"))
            .email(object.getString("email"))
            .gender(AuthUserGender.UNKNOWN)
            .token(authToken)
58
            .source(source)
不合群的混子's avatar
不合群的混子 已提交
59 60 61 62
            .build();
    }

    /**
63
     * 返回带{@code state}参数的授权url,授权回调时会带上这个{@code state}
不合群的混子's avatar
不合群的混子 已提交
64
     *
65
     * @param state state 验证授权流程的参数,可以防止csrf
不合群的混子's avatar
不合群的混子 已提交
66
     * @return 返回授权地址
智布道's avatar
智布道 已提交
67
     * @since 1.9.3
不合群的混子's avatar
不合群的混子 已提交
68 69
     */
    @Override
70
    public String authorize(String state) {
不合群的混子's avatar
不合群的混子 已提交
71 72 73 74 75
        return UrlBuilder.fromBaseUrl(source.authorize())
            .queryParam("response_type", "code")
            .queryParam("client_id", config.getClientId())
            .queryParam("scope", "openid%20email%20profile")
            .queryParam("redirect_uri", config.getRedirectUri())
76
            .queryParam("state", getRealState(state))
不合群的混子's avatar
不合群的混子 已提交
77 78 79 80 81 82
            .build();
    }

    /**
     * 返回获取userInfo的url
     *
83
     * @param authToken 用户授权后的token
不合群的混子's avatar
不合群的混子 已提交
84 85 86 87
     * @return 返回获取userInfo的url
     */
    @Override
    protected String userInfoUrl(AuthToken authToken) {
88
        return UrlBuilder.fromBaseUrl(source.userInfo()).queryParam("access_token", authToken.getAccessToken()).build();
89
    }
智布道's avatar
智布道 已提交
90 91 92 93 94 95 96 97

    /**
     * 检查响应内容是否正确
     *
     * @param object 请求响应内容
     */
    private void checkResponse(JSONObject object) {
        if (object.containsKey("error") || object.containsKey("error_description")) {
98
            throw new AuthException(object.containsKey("error") + ":" + object.getString("error_description"));
智布道's avatar
智布道 已提交
99 100
        }
    }
101
}