AuthTaobaoRequest.java 2.9 KB
Newer Older
1 2 3 4
package me.zhyd.oauth.request;

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

/**
 * 淘宝登录
 *
 * @author yadong.zhang (yadong.zhang0415(a)gmail.com)
智布道's avatar
智布道 已提交
20
 * @since 1.1.0
21
 */
智布道's avatar
智布道 已提交
22
public class AuthTaobaoRequest extends AuthDefaultRequest {
23 24

    public AuthTaobaoRequest(AuthConfig config) {
25
        super(config, AuthDefaultSource.TAOBAO);
26 27
    }

28
    public AuthTaobaoRequest(AuthConfig config, AuthStateCache authStateCache) {
29
        super(config, AuthDefaultSource.TAOBAO, authStateCache);
30 31
    }

32
    @Override
33 34
    protected AuthToken getAccessToken(AuthCallback authCallback) {
        return AuthToken.builder().accessCode(authCallback.getCode()).build();
35 36 37 38
    }

    @Override
    protected AuthUser getUserInfo(AuthToken authToken) {
不合群的混子's avatar
不合群的混子 已提交
39
        HttpResponse response = doPostAuthorizationCode(authToken.getAccessCode());
智布道's avatar
智布道 已提交
40 41
        JSONObject accessTokenObject = JSONObject.parseObject(response.body());
        if (accessTokenObject.containsKey("error")) {
智布道's avatar
智布道 已提交
42
            throw new AuthException(accessTokenObject.getString("error_description"));
43
        }
智布道's avatar
智布道 已提交
44 45 46 47 48
        authToken.setAccessToken(accessTokenObject.getString("access_token"));
        authToken.setRefreshToken(accessTokenObject.getString("refresh_token"));
        authToken.setExpireIn(accessTokenObject.getIntValue("expires_in"));
        authToken.setUid(accessTokenObject.getString("taobao_user_id"));
        authToken.setOpenId(accessTokenObject.getString("taobao_open_uid"));
49

智布道's avatar
智布道 已提交
50
        String nick = GlobalAuthUtil.urlDecode(accessTokenObject.getString("taobao_user_nick"));
51
        return AuthUser.builder()
不合群的混子's avatar
不合群的混子 已提交
52 53 54 55 56
            .uuid(accessTokenObject.getString("taobao_user_id"))
            .username(nick)
            .nickname(nick)
            .gender(AuthUserGender.UNKNOWN)
            .token(authToken)
57
            .source(source.toString())
不合群的混子's avatar
不合群的混子 已提交
58 59 60 61
            .build();
    }

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