CasAuthorizeEndpoint.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 23 24 25 26 27 28 29 30 31
/**
 * 
 */
package org.maxkey.authz.cas.endpoint;

import java.util.List;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.maxkey.authz.cas.endpoint.ticket.CasConstants;
import org.maxkey.authz.cas.endpoint.ticket.ServiceTicketImpl;
import org.maxkey.authz.cas.endpoint.ticket.service.TicketServices;
import org.maxkey.authz.endpoint.AuthorizeBaseEndpoint;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
32
import org.maxkey.configuration.ApplicationConfig;
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
33
import org.maxkey.domain.apps.AppsCasDetails;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
34
import org.maxkey.persistence.service.AppsCasDetailsService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
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.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.servlet.ModelAndView;

/**
 * @author Crystal.Sea
 * https://apereo.github.io/cas/5.0.x/protocol/CAS-Protocol-V2-Specification.html
 */
@Controller
public class CasAuthorizeEndpoint  extends AuthorizeBaseEndpoint{

	final static Logger _logger = LoggerFactory.getLogger(CasAuthorizeEndpoint.class);

	@Autowired
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
57
	AppsCasDetailsService casDetailsService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
58 59 60 61 62 63 64 65 66 67 68 69 70 71
	
	@Autowired
	ApplicationConfig applicationConfig;
	
	@Autowired
	@Qualifier("casTicketServices")
	TicketServices ticketServices;
	
	@RequestMapping("/authz/cas/login")
	public ModelAndView casLogin(
			HttpServletRequest request,
			HttpServletResponse response,
			@RequestParam(value=CasConstants.PARAMETER.SERVICE,required=false) String casService){
		
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
72
		AppsCasDetails casDetails=new AppsCasDetails();
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
73 74
		casDetails.setService(casService);
		
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
75
		List<AppsCasDetails> casDetailsList=casDetailsService.query(casDetails);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
76 77 78 79 80 81 82 83 84 85 86 87 88
		
		casDetails=(casDetailsList!=null && casDetailsList.size()==1)?casDetailsList.get(0):null;
		
		return buildCasModelAndView(casDetails);
		
	}
	
	@RequestMapping("/authz/cas/{id}")
	public ModelAndView authorize(
			HttpServletRequest request,
			HttpServletResponse response,
			@PathVariable("id") String id){
		
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
89
		AppsCasDetails casDetails=casDetailsService.getAppDetails(id);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
90 91 92 93
		
		return buildCasModelAndView(casDetails);
	}
	
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
94
	private  ModelAndView buildCasModelAndView(AppsCasDetails casDetails){
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
95 96 97 98 99
		
		_logger.debug(""+casDetails);

		WebContext.setAttribute(CasConstants.PARAMETER.ENDPOINT_CAS_DETAILS, casDetails);
		WebContext.setAttribute(WebConstants.SINGLE_SIGN_ON_APP_ID, casDetails.getId());
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
100
		WebContext.setAttribute(AuthorizeBaseEndpoint.class.getName(),casDetails);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
101 102 103 104 105 106 107 108
		return WebContext.redirect("/authz/cas/granting");
	}
	
	@RequestMapping("/authz/cas/granting")
	public ModelAndView grantingTicket(
			HttpServletRequest request,
			HttpServletResponse response){
		
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
109
		AppsCasDetails casDetails=(AppsCasDetails)WebContext.getAttribute(CasConstants.PARAMETER.ENDPOINT_CAS_DETAILS);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
110 111 112 113
		ServiceTicketImpl serviceTicket=new ServiceTicketImpl(WebContext.getAuthentication(),casDetails);
		
		String ticket=ticketServices.createTicket(serviceTicket);
		
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
114 115 116 117 118 119 120 121 122 123 124 125
		StringBuffer callbackUrl = new StringBuffer(casDetails.getCallbackUrl());
		if(casDetails.getCallbackUrl().indexOf("?")==-1) {
		    callbackUrl.append("?");
		}
		
		callbackUrl.append(CasConstants.PARAMETER.TICKET).append("=").append(ticket)
                .append("&")
                .append(CasConstants.PARAMETER.SERVICE).append("=").append(casDetails.getService());
		
		_logger.debug("redirect to CAS Client URL " + callbackUrl);
		
		return WebContext.redirect(callbackUrl.toString());
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
126 127
	}
}