package me.zhyd.oauth.request; import cn.hutool.http.HttpRequest; import cn.hutool.http.HttpResponse; import com.alibaba.fastjson.JSONObject; import me.zhyd.oauth.config.AuthConfig; import me.zhyd.oauth.exception.AuthException; import me.zhyd.oauth.model.AuthResponse; import me.zhyd.oauth.model.AuthSource; import me.zhyd.oauth.model.AuthUser; import me.zhyd.oauth.utils.AuthConfigChecker; import me.zhyd.oauth.utils.UrlBuilder; import javax.servlet.http.HttpServletResponse; import java.io.IOException; /** * @author yadong.zhang (yadong.zhang0415(a)gmail.com) * @version 1.0 * @website https://www.zhyd.me * @date 2019/1/31 16:31 * @since 1.8 */ public class AuthGiteeRequest implements AuthRequest { @Override public void authorize(AuthConfig config, HttpServletResponse response) { if (!AuthConfigChecker.isSupportedGitee()) { throw new AuthException(ResponseStatus.UNSUPPORTED); } String authorizeUrl = UrlBuilder.getGiteeAuthorizeUrl(config.getClientId(), config.getRedirectUri()); try { response.sendRedirect(authorizeUrl); } catch (IOException e) { e.printStackTrace(); } } @Override public String authorize(AuthConfig config) { if (!AuthConfigChecker.isSupportedGitee()) { throw new AuthException(ResponseStatus.UNSUPPORTED); } return UrlBuilder.getGiteeAuthorizeUrl(config.getClientId(), config.getRedirectUri()); } @Override public AuthResponse login(AuthConfig config, String code) { if (!AuthConfigChecker.isSupportedGitee()) { return AuthResponse.builder() .code(ResponseStatus.UNSUPPORTED.getCode()) .msg(ResponseStatus.UNSUPPORTED.getMsg()) .build(); } String accessTokenUrl = UrlBuilder.getGiteeAccessTokenUrl(config.getClientId(), config.getClientSecret(), code, config.getRedirectUri()); HttpResponse response = HttpRequest.post(accessTokenUrl).execute(); String accessTokenStr = response.body(); JSONObject accessTokenObject = JSONObject.parseObject(accessTokenStr); if (accessTokenObject.containsKey("error")) { return AuthResponse.builder() .code(500) .msg("Unable to get token from gitee using code [" + code + "]") .build(); } String accessToken = accessTokenObject.getString("access_token"); response = HttpRequest.get(UrlBuilder.getGiteeUserInfoUrl(accessToken)).execute(); String userInfo = response.body(); JSONObject object = JSONObject.parseObject(userInfo); return AuthResponse.builder() .data(AuthUser.builder() .username(object.getString("login")) .avatar(object.getString("avatar_url")) .blog(object.getString("blog")) .nickname(object.getString("name")) .company(object.getString("company")) .location(object.getString("address")) .email(object.getString("email")) .remark(object.getString("bio")) .source(AuthSource.GITEE) .build()) .build(); } }