| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 |
- package jnpf.socials.request;
- import com.alibaba.fastjson.JSON;
- import com.alibaba.fastjson.JSONObject;
- import jnpf.socials.enums.AuthDefaultSourceNew;
- import com.xkcoding.http.support.HttpHeader;
- import jnpf.constant.MsgCode;
- import me.zhyd.oauth.cache.AuthStateCache;
- import me.zhyd.oauth.config.AuthConfig;
- import me.zhyd.oauth.enums.AuthResponseStatus;
- import me.zhyd.oauth.enums.AuthUserGender;
- import me.zhyd.oauth.exception.AuthException;
- import me.zhyd.oauth.log.Log;
- import me.zhyd.oauth.model.AuthCallback;
- import me.zhyd.oauth.model.AuthResponse;
- import me.zhyd.oauth.model.AuthToken;
- import me.zhyd.oauth.model.AuthUser;
- import me.zhyd.oauth.request.AuthDefaultRequest;
- import me.zhyd.oauth.utils.HttpUtils;
- import me.zhyd.oauth.utils.StringUtils;
- import me.zhyd.oauth.utils.UrlBuilder;
- import java.io.UnsupportedEncodingException;
- import java.net.URLEncoder;
- /**
- * 流程设计
- *
- * @author JNPF开发平台组
- * @version V3.4.2
- * @copyright 引迈信息技术有限公司
- * @date 2022/7/15 17:19:14
- */
- public class AuthDingTalkNewRequest extends AuthDefaultRequest {
- public AuthDingTalkNewRequest(AuthConfig config) {
- super(config, AuthDefaultSourceNew.DINGTALK);
- }
- public AuthDingTalkNewRequest(AuthConfig config, AuthStateCache authStateCache) {
- super(config, AuthDefaultSourceNew.DINGTALK, authStateCache);
- }
- @Override
- public String authorize(String state) {
- String encode = null;
- try {
- encode = URLEncoder.encode(this.config.getRedirectUri(), "UTF-8");
- } catch (UnsupportedEncodingException e) {
- e.printStackTrace();
- }
- ;
- return UrlBuilder.fromBaseUrl(this.source.authorize())
- .queryParam("response_type", "code")
- .queryParam("client_id", this.config.getClientId())
- .queryParam("scope", "openid")
- .queryParam("redirect_uri", encode)
- .queryParam("prompt", "consent").build();
- }
- @Override
- public AuthToken getAccessToken(AuthCallback authCallback) {
- return this.getToken(this.accessTokenUrl(authCallback.getCode()), authCallback);
- }
- @Override
- protected String accessTokenUrl(String code) {
- return UrlBuilder.fromBaseUrl(this.source.accessToken()).build();
- }
- @Override
- public AuthResponse login(AuthCallback authCallback) {
- try {
- this.checkCode(authCallback);
- AuthToken authToken = this.getAccessToken(authCallback);
- AuthUser user = this.getUserInfo(authToken);
- return AuthResponse.builder().code(AuthResponseStatus.SUCCESS.getCode()).data(user).build();
- } catch (Exception var4) {
- Log.error("Failed to login with oauth authorization.", var4);
- return this.responseError(var4);
- }
- }
- AuthResponse responseError(Exception e) {
- int errorCode = AuthResponseStatus.FAILURE.getCode();
- String errorMsg = e.getMessage();
- if (e instanceof AuthException) {
- AuthException authException = (AuthException) e;
- errorCode = authException.getErrorCode();
- if (StringUtils.isNotEmpty(authException.getErrorMsg())) {
- errorMsg = authException.getErrorMsg();
- }
- }
- return AuthResponse.builder().code(errorCode).msg(errorMsg).build();
- }
- private AuthToken getToken(String accessTokenUrl, AuthCallback authCallback) {
- JSONObject map = new JSONObject();
- map.put("clientId", this.config.getClientId());
- map.put("clientSecret", this.config.getClientSecret());
- map.put("code", authCallback.getCode());
- map.put("refreshToken", authCallback.getCode());
- map.put("grantType", "authorization_code");
- String response = (new HttpUtils(this.config.getHttpConfig())).post(accessTokenUrl, map.toJSONString(), new HttpHeader().add("Content-Type", "application/json")).getBody();
- JSONObject accessTokenObject = JSONObject.parseObject(response);
- this.checkResponse(accessTokenObject);
- return AuthToken.builder().accessToken(accessTokenObject.getString("accessToken")).refreshToken(accessTokenObject.getString("refreshToken")).expireIn(accessTokenObject.getIntValue("expireIn")).openId(accessTokenObject.getString("openid")).build();
- }
- private void checkResponse(JSONObject object) {
- if (object.containsKey("errcode")) {
- throw new AuthException(object.getIntValue("errcode"), object.getString("errmsg"));
- }
- }
- @Override
- public AuthUser getUserInfo(AuthToken authToken) {
- HttpHeader httpHeader = new HttpHeader()
- .add("x-acs-dingtalk-access-token", authToken.getAccessToken())
- .add("Content-Type", "application/json");
- String response = (new HttpUtils(this.config.getHttpConfig())).get(this.userInfoUrl(authToken), null, httpHeader, false).getHttpResponse().getBody();
- JSONObject object = JSON.parseObject(response);
- if (object.get("unionId") != null) {
- AuthToken token = AuthToken.builder().openId(object.getString("openId")).unionId(object.getString("unionId")).build();
- 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();
- } else {
- throw new AuthException(MsgCode.OA024.get());
- }
- }
- @Override
- protected String userInfoUrl(AuthToken authToken) {
- return UrlBuilder.fromBaseUrl(this.source.userInfo()).build();
- }
- }
|