AuthFacebookRequest.java 3.9 KB
Newer Older
1 2 3
package me.zhyd.oauth.request;

import com.alibaba.fastjson.JSONObject;
4
import me.zhyd.oauth.cache.AuthStateCache;
5
import me.zhyd.oauth.config.AuthConfig;
6
import me.zhyd.oauth.config.AuthDefaultSource;
智布道's avatar
智布道 已提交
7
import me.zhyd.oauth.enums.AuthUserGender;
智布道's avatar
智布道 已提交
8
import me.zhyd.oauth.enums.scope.AuthFacebookScope;
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

/**
 * Facebook登录
 *
 * @author yadong.zhang (yadong.zhang0415(a)gmail.com)
智布道's avatar
智布道 已提交
19
 * @since 1.3.0
20
 */
智布道's avatar
智布道 已提交
21
public class AuthFacebookRequest extends AuthDefaultRequest {
22 23

    public AuthFacebookRequest(AuthConfig config) {
24
        super(config, AuthDefaultSource.FACEBOOK);
25 26
    }

27
    public AuthFacebookRequest(AuthConfig config, AuthStateCache authStateCache) {
28
        super(config, AuthDefaultSource.FACEBOOK, authStateCache);
29 30
    }

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

    @Override
    protected AuthUser getUserInfo(AuthToken authToken) {
45
        String userInfo = doGetUserInfo(authToken);
46
        JSONObject object = JSONObject.parseObject(userInfo);
智布道's avatar
智布道 已提交
47
        this.checkResponse(object);
48
        return AuthUser.builder()
49
            .rawUserInfo(object)
不合群的混子's avatar
不合群的混子 已提交
50 51 52
            .uuid(object.getString("id"))
            .username(object.getString("name"))
            .nickname(object.getString("name"))
53
            .blog(object.getString("link"))
智布道's avatar
智布道 已提交
54
            .avatar(getUserPicture(object))
不合群的混子's avatar
不合群的混子 已提交
55 56 57 58
            .location(object.getString("locale"))
            .email(object.getString("email"))
            .gender(AuthUserGender.getRealGender(object.getString("gender")))
            .token(authToken)
59
            .source(source.toString())
不合群的混子's avatar
不合群的混子 已提交
60 61 62
            .build();
    }

智布道's avatar
智布道 已提交
63 64 65 66 67 68 69 70 71 72 73 74
    private String getUserPicture(JSONObject object) {
        String picture = null;
        if (object.containsKey("picture")) {
            JSONObject pictureObj = object.getJSONObject("picture");
            pictureObj = pictureObj.getJSONObject("data");
            if (null != pictureObj) {
                picture = pictureObj.getString("url");
            }
        }
        return picture;
    }

不合群的混子's avatar
不合群的混子 已提交
75 76 77
    /**
     * 返回获取userInfo的url
     *
智布道's avatar
智布道 已提交
78
     * @param authToken 用户token
不合群的混子's avatar
不合群的混子 已提交
79 80 81 82 83 84
     * @return 返回获取userInfo的url
     */
    @Override
    protected String userInfoUrl(AuthToken authToken) {
        return UrlBuilder.fromBaseUrl(source.userInfo())
            .queryParam("access_token", authToken.getAccessToken())
85
            .queryParam("fields", "id,name,birthday,gender,hometown,email,devices,picture.width(400),link")
不合群的混子's avatar
不合群的混子 已提交
86
            .build();
87
    }
智布道's avatar
智布道 已提交
88 89 90 91 92 93 94 95 96 97 98

    /**
     * 检查响应内容是否正确
     *
     * @param object 请求响应内容
     */
    private void checkResponse(JSONObject object) {
        if (object.containsKey("error")) {
            throw new AuthException(object.getJSONObject("error").getString("message"));
        }
    }
智布道's avatar
智布道 已提交
99 100 101 102 103 104 105 106 107 108 109 110 111 112

    /**
     * 返回带{@code state}参数的授权url,授权回调时会带上这个{@code state}
     *
     * @param state state 验证授权流程的参数,可以防止csrf
     * @return 返回授权地址
     */
    @Override
    public String authorize(String state) {
        String authorizeUrl = super.authorize(state);
        return UrlBuilder.fromBaseUrl(authorizeUrl)
            .queryParam("scope", this.getScopes(",", false, AuthFacebookScope.getDefaultScopes()))
            .build();
    }
113
}