AbstractSocialSignOnEndpoint.java 4.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;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
24 25
import org.maxkey.authn.support.socialsignon.service.SocialSignOnProvider;
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;
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 62 63
/**
 * @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";
	}
	
	
	protected SocialSignOnProvider socialSignOnProvider;
	
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 87 88 89 90 91 92 93 94 95 96 97 98
  		try {
			SocialSignOnProvider socialSignOnProvider = socialSignOnProviderService.get(provider);
			_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
 		authRequest=(AuthRequest)WebContext.getAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION);
 		socialSignOnProvider=(SocialSignOnProvider)WebContext.getAttribute(SOCIALSIGNON_PROVIDER_SESSION);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
105 106
  		WebContext.removeAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION);
  		WebContext.removeAttribute(SOCIALSIGNON_PROVIDER_SESSION);
107 108 109 110
  		
  		AuthCallback authCallback=new AuthCallback();
  		authCallback.setCode(WebContext.getRequest().getParameter("code"));
  		authCallback.setAuth_code(WebContext.getRequest().getParameter("auth_code"));
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
111
  		authCallback.setOauth_token(WebContext.getRequest().getParameter("oauthToken"));
112
  		authCallback.setAuthorization_code(WebContext.getRequest().getParameter("authorization_code"));
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
113
  		authCallback.setOauth_verifier(WebContext.getRequest().getParameter("oauthVerifier"));
114 115 116 117 118
  		authCallback.setState(WebContext.getRequest().getParameter("state"));
  		
  		AuthResponse<?> authResponse=authRequest.login(authCallback);
  		_logger.debug("Response  : "+authResponse);
  		accountId=socialSignOnProviderService.getAccountId(socialSignOnProvider.getProvider(), authResponse);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
119 120 121 122 123 124 125
 		
 		_logger.debug("getAccountId : "+accountId);
 		return accountId;
 	}
  	

}