AbstractSocialSignOnEndpoint.java 5.4 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;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
24
import org.maxkey.authn.support.socialsignon.service.SocialSignOnProviderService;
MaxKey单点登录官方's avatar
fix  
MaxKey单点登录官方 已提交
25
import org.maxkey.authn.support.socialsignon.service.SocialsAssociateService;
M
MaxKey 已提交
26
import org.maxkey.configuration.ApplicationConfig;
27
import org.maxkey.entity.SocialsProvider;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
28 29 30 31
import org.maxkey.web.WebContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
32
import org.springframework.beans.factory.annotation.Qualifier;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
33

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

MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
/**
 * @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";
	}
	
	
62
	protected SocialsProvider socialSignOnProvider;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
63
	
64
	protected AuthRequest authRequest;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
65 66 67 68 69 70 71 72 73 74 75
	
	protected String accountJsonString;
	
	protected String accountId;
	
	protected String provider;
	
	@Autowired
	protected SocialSignOnProviderService socialSignOnProviderService;
	
	@Autowired
MaxKey单点登录官方's avatar
fix  
MaxKey单点登录官方 已提交
76
	protected SocialsAssociateService socialsAssociateService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
77
	
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
78 79
	@Autowired
    @Qualifier("authenticationProvider")
80
	AbstractAuthenticationProvider authenticationProvider ;
M
MaxKey 已提交
81 82 83
	
	@Autowired
	ApplicationConfig applicationConfig;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
84
 	
85
  	protected AuthRequest buildAuthRequest(String provider){
M
MaxKey 已提交
86
  		try {
87
			SocialsProvider socialSignOnProvider = socialSignOnProviderService.get(provider);
M
MaxKey 已提交
88 89 90 91 92 93 94 95 96 97 98
			_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单点登录官方 已提交
99 100
		return null;
	}
101
    	
M
MaxKey 已提交
102
	protected String  authCallback()  throws Exception {
103 104 105 106 107 108 109 110 111 112 113 114 115
	    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单点登录官方 已提交
116 117
        _logger.debug("Callback state {} , sessionId {}", 
                    authCallback.getState(),WebContext.getRequest().getSession().getId()
118 119
                );
        
120
 		authRequest=(AuthRequest)WebContext.getAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION);
121 122
 		socialSignOnProvider=(SocialsProvider)WebContext.getAttribute(SOCIALSIGNON_PROVIDER_SESSION);
 		//clear session
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
123 124
  		WebContext.removeAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION);
  		WebContext.removeAttribute(SOCIALSIGNON_PROVIDER_SESSION);
125 126

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