LoginEndpoint.java 7.9 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
package org.maxkey.web.endpoint;

20
import java.io.IOException;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
21 22
import java.util.HashMap;

23
import javax.servlet.ServletException;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
24 25 26
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

27
import org.maxkey.authn.AbstractAuthenticationProvider;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
28
import org.maxkey.authn.BasicAuthentication;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
29 30 31 32
import org.maxkey.authn.support.kerberos.KerberosService;
import org.maxkey.authn.support.rememberme.AbstractRemeberMeService;
import org.maxkey.authn.support.socialsignon.service.SocialSignOnProviderService;
import org.maxkey.authn.support.wsfederation.WsFederationConstants;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
33
import org.maxkey.configuration.ApplicationConfig;
34
import org.maxkey.crypto.password.opt.AbstractOptAuthn;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
35
import org.maxkey.domain.UserInfo;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
36
import org.maxkey.persistence.service.UserInfoService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
37 38 39 40 41 42 43 44 45
import org.maxkey.util.StringUtils;
import org.maxkey.web.WebConstants;
import org.maxkey.web.WebContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.CookieValue;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
46
import org.springframework.web.bind.annotation.ModelAttribute;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;


/**
 * @author Crystal.Sea
 *
 */
@Controller
public class LoginEndpoint {
	private static Logger _logger = LoggerFactory.getLogger(LoginEndpoint.class);
	
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
62 63
	
	
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
	@Autowired
  	@Qualifier("applicationConfig")
  	ApplicationConfig applicationConfig;
 	
	@Autowired
	@Qualifier("socialSignOnProviderService")
	SocialSignOnProviderService socialSignOnProviderService;
	
	@Autowired
	@Qualifier("remeberMeService")
	AbstractRemeberMeService remeberMeService;
	
	@Autowired
	@Qualifier("kerberosService")
	KerberosService kerberosService;
	
	@Autowired
	@Qualifier("userInfoService")
	UserInfoService userInfoService;
	
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
84
	/*@Autowired
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
85
	@Qualifier("wsFederationService")
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
86
	WsFederationService wsFederationService;*/
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
87
	
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
88 89
	@Autowired
	@Qualifier("authenticationProvider")
90
	AbstractAuthenticationProvider authenticationProvider ;
91 92 93 94 95
	
	@Autowired
    @Qualifier("tfaOptAuthn")
    protected AbstractOptAuthn tfaOptAuthn;
	
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
96
	/*
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
97 98 99
	@Autowired
	@Qualifier("jwtLoginService")
	JwtLoginService jwtLoginService;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
100
	*/
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
	/**
	 * init login
	 * @return
	 */
 	@RequestMapping(value={"/login"})
	public ModelAndView login(
			HttpServletRequest request,
			HttpServletResponse response,
			@CookieValue(value=WebConstants.REMEBER_ME_COOKIE,required=false) String remeberMe,
			@RequestParam(value=WebConstants.CAS_SERVICE_PARAMETER,required=false) String casService,
			@RequestParam(value=WebConstants.KERBEROS_TOKEN_PARAMETER,required=false) String kerberosToken,
			@RequestParam(value=WebConstants.KERBEROS_USERDOMAIN_PARAMETER,required=false) String kerberosUserDomain,
			@RequestParam(value=WsFederationConstants.WA,required=false) String wsFederationWA,
			@RequestParam(value=WsFederationConstants.WRESULT,required=false) String wsFederationWResult) {
 		
		_logger.debug("LoginController /login.");
MaxKey单点登录官方's avatar
am  
MaxKey单点登录官方 已提交
117
		ModelAndView modelAndView = new ModelAndView("login");
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
118 119 120 121 122
		
		boolean isAuthenticated= WebContext.isAuthenticated();
		//for RemeberMe login
		if(!isAuthenticated){
			if(applicationConfig.getLoginConfig().isRemeberMe()&&remeberMe!=null&& !remeberMe.equals("")){
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
123
				_logger.debug("Try RemeberMe login ");
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
124 125 126 127 128 129 130 131
				isAuthenticated=remeberMeService.login(remeberMe,response);
			}
		}
		//for Kerberos login
		if(!isAuthenticated){
			if(applicationConfig.getLoginConfig().isKerberos()&&
					kerberosUserDomain!=null&&!kerberosUserDomain.equals("")&&
					kerberosToken!=null && !kerberosToken.equals("")){
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
132
				_logger.debug("Try Kerberos login ");
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
133 134 135 136 137 138 139 140
				isAuthenticated=kerberosService.login(kerberosToken,kerberosUserDomain);
			}
		}
		//for WsFederation login
		if(!isAuthenticated){
			if(applicationConfig.getLoginConfig().isWsFederation()&&
					StringUtils.isNotEmpty(wsFederationWA) && 
					wsFederationWA.equalsIgnoreCase(WsFederationConstants.WSIGNIN)){
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
141
				_logger.debug("Try WsFederation login ");
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
142
				//isAuthenticated=wsFederationService.login(wsFederationWA,wsFederationWResult,request);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
143 144 145 146 147 148 149
			}
		}
				
		//for normal login
		if(!isAuthenticated){
			modelAndView.addObject("isRemeberMe", applicationConfig.getLoginConfig().isRemeberMe());
			modelAndView.addObject("isKerberos", applicationConfig.getLoginConfig().isKerberos());
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
150 151
			modelAndView.addObject("isMfa", applicationConfig.getLoginConfig().isMfa());
			if(applicationConfig.getLoginConfig().isMfa()) {
152 153 154 155
			    modelAndView.addObject("optType", tfaOptAuthn.getOptType());
			    modelAndView.addObject("optInterval", tfaOptAuthn.getInterval());
			}
			
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
156 157 158 159 160 161
			if( applicationConfig.getLoginConfig().isKerberos()){
				modelAndView.addObject("userDomainUrlJson", kerberosService.buildKerberosProxys());
				
			}
			modelAndView.addObject("isCaptcha", applicationConfig.getLoginConfig().isCaptcha());
			modelAndView.addObject("sessionid", WebContext.getSession().getId());
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
162
			//modelAndView.addObject("jwtToken",jwtLoginService.buildLoginJwt());
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
163 164
			//load Social Sign On Providers
			if(applicationConfig.getLoginConfig().isSocialSignOn()){
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
165
				_logger.debug("Load Social Sign On Providers ");
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
166 167 168
				modelAndView.addObject("ssopList", socialSignOnProviderService.getSocialSignOnProviders());
			}
		}
169
		
MaxKey单点登录官方's avatar
am  
MaxKey单点登录官方 已提交
170
		
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
171
		if(isAuthenticated){
MaxKey单点登录官方's avatar
am  
MaxKey单点登录官方 已提交
172
			return  WebContext.redirect("/forwardindex");
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
173
		}
MaxKey单点登录官方's avatar
am  
MaxKey单点登录官方 已提交
174
		
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
175 176 177
		Object loginErrorMessage=WebContext.getAttribute(WebConstants.LOGIN_ERROR_SESSION_MESSAGE);
        modelAndView.addObject("loginErrorMessage", loginErrorMessage==null?"":loginErrorMessage);
        WebContext.removeAttribute(WebConstants.LOGIN_ERROR_SESSION_MESSAGE);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
178 179
		return modelAndView;
	}
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
180 181
 	
 	@RequestMapping(value={"/logon.do"})
182 183 184 185
	public ModelAndView logon(
	                    HttpServletRequest request,
	                    HttpServletResponse response,
	                    @ModelAttribute("authentication") BasicAuthentication authentication) throws ServletException, IOException {
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
186 187 188 189 190 191 192 193

        authenticationProvider.authenticate(authentication);

        if (WebContext.isAuthenticated()) {
            return WebContext.redirect("/forwardindex");
        } else {
            return WebContext.redirect("/login");
        }
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
194 195
 		
 	}
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
196 197 198 199 200 201 202 203 204 205 206 207 208 209 210
	
 	
 	@RequestMapping("/login/{username}")
	@ResponseBody
	public HashMap <String,Object> queryLoginUserAuth(@PathVariable("username") String username) {
 		UserInfo userInfo=new UserInfo();
 		userInfo.setUsername(username);
 		userInfo=userInfoService.load(userInfo);
 		
 		HashMap <String,Object> authnType=new HashMap <String,Object>();
 		authnType.put("authnType", userInfo.getAuthnType());
 		authnType.put("appLoginAuthnType", userInfo.getAppLoginAuthnType());
 		
 		return authnType;
 	}
211 212 213 214 215 216 217 218 219 220 221 222 223 224
 	
 	@RequestMapping("/login/otp/{username}")
    @ResponseBody
    public String produceOtp(@PathVariable("username") String username) {
        UserInfo userInfo = new UserInfo();
        userInfo.setUsername(username);
        UserInfo queryUserInfo=userInfoService.loadByUsername(username);//(userInfo);
        if(queryUserInfo!=null) {
            tfaOptAuthn.produce(queryUserInfo);
            return "ok";
        }
        
        return "fail";
    }
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
225
}