AbstractSocialSignOnEndpoint.java 5.5 KB
Newer Older
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
/*
 * Copyright [2020] [MaxKey of copyright http://www.maxkey.top]
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *     http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
 

MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
18 19 20 21 22
/**
 * 
 */
package org.maxkey.authn.support.socialsignon;

23
import org.maxkey.authn.AbstractAuthenticationProvider;
M
MaxKey 已提交
24
import org.maxkey.authn.jwt.AuthJwtService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
25
import org.maxkey.authn.support.socialsignon.service.SocialSignOnProviderService;
MaxKey单点登录官方's avatar
fix  
MaxKey单点登录官方 已提交
26
import org.maxkey.authn.support.socialsignon.service.SocialsAssociateService;
M
MaxKey 已提交
27
import org.maxkey.configuration.ApplicationConfig;
28
import org.maxkey.entity.SocialsProvider;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
29 30 31 32
import org.maxkey.web.WebContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
33
import org.springframework.beans.factory.annotation.Qualifier;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
34

35 36 37 38
import me.zhyd.oauth.model.AuthCallback;
import me.zhyd.oauth.model.AuthResponse;
import me.zhyd.oauth.request.AuthRequest;

MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
/**
 * @author Crystal.Sea
 *
 */
public class AbstractSocialSignOnEndpoint {
	final static Logger _logger = LoggerFactory.getLogger(AbstractSocialSignOnEndpoint.class);

	protected final static String SOCIALSIGNON_SESSION_REDIRECT_URI="socialsignon_session_redirect_uri";
	
	protected final static String SOCIALSIGNON_REDIRECT_URI="redirect_uri";
	
	public  final static String SOCIALSIGNON_TYPE_SESSION="socialsignon_type_session";
	
	public  final static String SOCIALSIGNON_OAUTH_SERVICE_SESSION="socialsignon_oauth_service_session";
	
	public  final static String SOCIALSIGNON_PROVIDER_SESSION="socialsignon_provider_session";
	
	
	public final static class SOCIALSIGNON_TYPE{
		public  final static String SOCIALSIGNON_TYPE_LOGON="socialsignon_type_logon";
		public  final static String SOCIALSIGNON_TYPE_BIND="socialsignon_type_bind";
	}
	
	
63
	protected SocialsProvider socialSignOnProvider;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
64
	
65
	protected AuthRequest authRequest;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
66 67 68 69 70 71 72 73 74 75 76
	
	protected String accountJsonString;
	
	protected String accountId;
	
	protected String provider;
	
	@Autowired
	protected SocialSignOnProviderService socialSignOnProviderService;
	
	@Autowired
MaxKey单点登录官方's avatar
fix  
MaxKey单点登录官方 已提交
77
	protected SocialsAssociateService socialsAssociateService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
78
	
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
79 80
	@Autowired
    @Qualifier("authenticationProvider")
81
	AbstractAuthenticationProvider authenticationProvider ;
M
MaxKey 已提交
82
	
M
MaxKey 已提交
83 84 85
	@Autowired
	AuthJwtService authJwtService;
	
M
MaxKey 已提交
86 87
	@Autowired
	ApplicationConfig applicationConfig;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
88
 	
89
  	protected AuthRequest buildAuthRequest(String provider){
M
MaxKey 已提交
90
  		try {
91
			SocialsProvider socialSignOnProvider = socialSignOnProviderService.get(provider);
M
MaxKey 已提交
92 93 94 95 96 97 98 99 100 101 102
			_logger.debug("socialSignOn Provider : "+socialSignOnProvider);
			
			if(socialSignOnProvider!=null){
				authRequest=socialSignOnProviderService.getAuthRequest(provider,applicationConfig);
				WebContext.setAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION, authRequest);
				WebContext.setAttribute(SOCIALSIGNON_PROVIDER_SESSION, socialSignOnProvider);
				return authRequest;
			}
  		}catch(Exception e) {
  			_logger.debug("buildAuthRequest Exception ",e);
  		}
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
103 104
		return null;
	}
105
    	
M
MaxKey 已提交
106
	protected String  authCallback()  throws Exception {
107 108 109 110 111 112 113 114 115 116 117 118 119
	    AuthCallback authCallback=new AuthCallback();
        authCallback.setCode(WebContext.getRequest().getParameter("code"));
        authCallback.setAuth_code(WebContext.getRequest().getParameter("auth_code"));
        authCallback.setOauth_token(WebContext.getRequest().getParameter("oauthToken"));
        authCallback.setAuthorization_code(WebContext.getRequest().getParameter("authorization_code"));
        authCallback.setOauth_verifier(WebContext.getRequest().getParameter("oauthVerifier"));
        authCallback.setState(WebContext.getRequest().getParameter("state"));
        _logger.debug("Callback OAuth code {}, auth_code {}, oauthToken {}, authorization_code {}, oauthVerifier {}", 
                authCallback.getCode(),
                authCallback.getAuth_code(),
                authCallback.getOauth_token(),
                authCallback.getAuthorization_code(),
                authCallback.getOauth_verifier());
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
120 121
        _logger.debug("Callback state {} , sessionId {}", 
                    authCallback.getState(),WebContext.getRequest().getSession().getId()
122 123
                );
        
124
 		authRequest=(AuthRequest)WebContext.getAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION);
125 126
 		socialSignOnProvider=(SocialsProvider)WebContext.getAttribute(SOCIALSIGNON_PROVIDER_SESSION);
 		//clear session
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
127 128
  		WebContext.removeAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION);
  		WebContext.removeAttribute(SOCIALSIGNON_PROVIDER_SESSION);
129 130

  		if(authRequest == null) {//if authRequest is null renew one
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
131 132
  		    authRequest=socialSignOnProviderService.getAuthRequest(provider,applicationConfig);  		    
  		    _logger.debug("session authRequest is null , renew one");
133
  		}
134
  		
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
135 136 137 138 139
  		//State time out, re set
  		if(authCallback.getState() != null) {
            authRequest.authorize(WebContext.getRequest().getSession().getId());
        }
  		
140
  		AuthResponse<?> authResponse=authRequest.login(authCallback);
141 142
  		_logger.debug("Response  : " + authResponse.getData());
  		accountId=socialSignOnProviderService.getAccountId(provider, authResponse);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
143
 		
144
 		_logger.debug("getAccountId : " + accountId);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
145 146 147 148
 		return accountId;
 	}
  	
}