AbstractSocialSignOnEndpoint.java 4.3 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;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
27 28 29 30
import org.maxkey.web.WebContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
31
import org.springframework.beans.factory.annotation.Qualifier;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
32

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

MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
37 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
/**
 * @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;
	
63
	protected AuthRequest authRequest;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
64 65 66 67 68 69 70 71 72 73 74
	
	protected String accountJsonString;
	
	protected String accountId;
	
	protected String provider;
	
	@Autowired
	protected SocialSignOnProviderService socialSignOnProviderService;
	
	@Autowired
MaxKey单点登录官方's avatar
fix  
MaxKey单点登录官方 已提交
75
	protected SocialsAssociateService socialsAssociateService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
76
	
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
77 78
	@Autowired
    @Qualifier("authenticationProvider")
79
	AbstractAuthenticationProvider authenticationProvider ;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
80
 	
81
  	protected AuthRequest buildAuthRequest(String provider){
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
82 83 84 85 86
  		
		SocialSignOnProvider socialSignOnProvider = socialSignOnProviderService.get(provider);
		_logger.debug("socialSignOn Provider : "+socialSignOnProvider);
		
		if(socialSignOnProvider!=null){
87 88 89 90
			authRequest=socialSignOnProviderService.getAuthRequest(provider);
			WebContext.setAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION, authRequest);
			WebContext.setAttribute(SOCIALSIGNON_PROVIDER_SESSION, socialSignOnProvider);
			return authRequest;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
91 92 93
		}
		return null;
	}
94 95 96 97
    	
	protected String  authCallback() {
 		authRequest=(AuthRequest)WebContext.getAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION);
 		socialSignOnProvider=(SocialSignOnProvider)WebContext.getAttribute(SOCIALSIGNON_PROVIDER_SESSION);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
98 99
  		WebContext.removeAttribute(SOCIALSIGNON_OAUTH_SERVICE_SESSION);
  		WebContext.removeAttribute(SOCIALSIGNON_PROVIDER_SESSION);
100 101 102 103
  		
  		AuthCallback authCallback=new AuthCallback();
  		authCallback.setCode(WebContext.getRequest().getParameter("code"));
  		authCallback.setAuth_code(WebContext.getRequest().getParameter("auth_code"));
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
104
  		authCallback.setOauth_token(WebContext.getRequest().getParameter("oauthToken"));
105
  		authCallback.setAuthorization_code(WebContext.getRequest().getParameter("authorization_code"));
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
106
  		authCallback.setOauth_verifier(WebContext.getRequest().getParameter("oauthVerifier"));
107 108 109 110 111
  		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单点登录官方 已提交
112 113 114 115 116 117 118
 		
 		_logger.debug("getAccountId : "+accountId);
 		return accountId;
 	}
  	

}