AuthDingTalkNewRequest.java 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. package jnpf.socials.request;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import jnpf.socials.enums.AuthDefaultSourceNew;
  5. import com.xkcoding.http.support.HttpHeader;
  6. import jnpf.constant.MsgCode;
  7. import me.zhyd.oauth.cache.AuthStateCache;
  8. import me.zhyd.oauth.config.AuthConfig;
  9. import me.zhyd.oauth.enums.AuthResponseStatus;
  10. import me.zhyd.oauth.enums.AuthUserGender;
  11. import me.zhyd.oauth.exception.AuthException;
  12. import me.zhyd.oauth.log.Log;
  13. import me.zhyd.oauth.model.AuthCallback;
  14. import me.zhyd.oauth.model.AuthResponse;
  15. import me.zhyd.oauth.model.AuthToken;
  16. import me.zhyd.oauth.model.AuthUser;
  17. import me.zhyd.oauth.request.AuthDefaultRequest;
  18. import me.zhyd.oauth.utils.HttpUtils;
  19. import me.zhyd.oauth.utils.StringUtils;
  20. import me.zhyd.oauth.utils.UrlBuilder;
  21. import java.io.UnsupportedEncodingException;
  22. import java.net.URLEncoder;
  23. /**
  24. * 流程设计
  25. *
  26. * @author JNPF开发平台组
  27. * @version V3.4.2
  28. * @copyright 引迈信息技术有限公司
  29. * @date 2022/7/15 17:19:14
  30. */
  31. public class AuthDingTalkNewRequest extends AuthDefaultRequest {
  32. public AuthDingTalkNewRequest(AuthConfig config) {
  33. super(config, AuthDefaultSourceNew.DINGTALK);
  34. }
  35. public AuthDingTalkNewRequest(AuthConfig config, AuthStateCache authStateCache) {
  36. super(config, AuthDefaultSourceNew.DINGTALK, authStateCache);
  37. }
  38. @Override
  39. public String authorize(String state) {
  40. String encode = null;
  41. try {
  42. encode = URLEncoder.encode(this.config.getRedirectUri(), "UTF-8");
  43. } catch (UnsupportedEncodingException e) {
  44. e.printStackTrace();
  45. }
  46. ;
  47. return UrlBuilder.fromBaseUrl(this.source.authorize())
  48. .queryParam("response_type", "code")
  49. .queryParam("client_id", this.config.getClientId())
  50. .queryParam("scope", "openid")
  51. .queryParam("redirect_uri", encode)
  52. .queryParam("prompt", "consent").build();
  53. }
  54. @Override
  55. public AuthToken getAccessToken(AuthCallback authCallback) {
  56. return this.getToken(this.accessTokenUrl(authCallback.getCode()), authCallback);
  57. }
  58. @Override
  59. protected String accessTokenUrl(String code) {
  60. return UrlBuilder.fromBaseUrl(this.source.accessToken()).build();
  61. }
  62. @Override
  63. public AuthResponse login(AuthCallback authCallback) {
  64. try {
  65. this.checkCode(authCallback);
  66. AuthToken authToken = this.getAccessToken(authCallback);
  67. AuthUser user = this.getUserInfo(authToken);
  68. return AuthResponse.builder().code(AuthResponseStatus.SUCCESS.getCode()).data(user).build();
  69. } catch (Exception var4) {
  70. Log.error("Failed to login with oauth authorization.", var4);
  71. return this.responseError(var4);
  72. }
  73. }
  74. AuthResponse responseError(Exception e) {
  75. int errorCode = AuthResponseStatus.FAILURE.getCode();
  76. String errorMsg = e.getMessage();
  77. if (e instanceof AuthException) {
  78. AuthException authException = (AuthException) e;
  79. errorCode = authException.getErrorCode();
  80. if (StringUtils.isNotEmpty(authException.getErrorMsg())) {
  81. errorMsg = authException.getErrorMsg();
  82. }
  83. }
  84. return AuthResponse.builder().code(errorCode).msg(errorMsg).build();
  85. }
  86. private AuthToken getToken(String accessTokenUrl, AuthCallback authCallback) {
  87. JSONObject map = new JSONObject();
  88. map.put("clientId", this.config.getClientId());
  89. map.put("clientSecret", this.config.getClientSecret());
  90. map.put("code", authCallback.getCode());
  91. map.put("refreshToken", authCallback.getCode());
  92. map.put("grantType", "authorization_code");
  93. String response = (new HttpUtils(this.config.getHttpConfig())).post(accessTokenUrl, map.toJSONString(), new HttpHeader().add("Content-Type", "application/json")).getBody();
  94. JSONObject accessTokenObject = JSONObject.parseObject(response);
  95. this.checkResponse(accessTokenObject);
  96. return AuthToken.builder().accessToken(accessTokenObject.getString("accessToken")).refreshToken(accessTokenObject.getString("refreshToken")).expireIn(accessTokenObject.getIntValue("expireIn")).openId(accessTokenObject.getString("openid")).build();
  97. }
  98. private void checkResponse(JSONObject object) {
  99. if (object.containsKey("errcode")) {
  100. throw new AuthException(object.getIntValue("errcode"), object.getString("errmsg"));
  101. }
  102. }
  103. @Override
  104. public AuthUser getUserInfo(AuthToken authToken) {
  105. HttpHeader httpHeader = new HttpHeader()
  106. .add("x-acs-dingtalk-access-token", authToken.getAccessToken())
  107. .add("Content-Type", "application/json");
  108. String response = (new HttpUtils(this.config.getHttpConfig())).get(this.userInfoUrl(authToken), null, httpHeader, false).getHttpResponse().getBody();
  109. JSONObject object = JSON.parseObject(response);
  110. if (object.get("unionId") != null) {
  111. AuthToken token = AuthToken.builder().openId(object.getString("openId")).unionId(object.getString("unionId")).build();
  112. return AuthUser.builder().rawUserInfo(object).uuid(object.getString("unionId")).nickname(object.getString("nick")).username(object.getString("nick")).gender(AuthUserGender.UNKNOWN).source(this.source.toString()).token(token).build();
  113. } else {
  114. throw new AuthException(MsgCode.OA024.get());
  115. }
  116. }
  117. @Override
  118. protected String userInfoUrl(AuthToken authToken) {
  119. return UrlBuilder.fromBaseUrl(this.source.userInfo()).build();
  120. }
  121. }