CasAuthorizeEndpoint.java 3.2 KB
Newer Older
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/**
 * 
 */
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;
import org.maxkey.config.ApplicationConfig;
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
16 17
import org.maxkey.dao.service.AppsCasDetailsService;
import org.maxkey.domain.apps.AppsCasDetails;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
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单点登录官方 已提交
40
	AppsCasDetailsService casDetailsService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
41 42 43 44 45 46 47 48 49 50 51 52 53 54
	
	@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单点登录官方 已提交
55
		AppsCasDetails casDetails=new AppsCasDetails();
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
56 57
		casDetails.setService(casService);
		
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
58
		List<AppsCasDetails> casDetailsList=casDetailsService.query(casDetails);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
59 60 61 62 63 64 65 66 67 68 69 70 71
		
		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
m-11/6  
MaxKey单点登录官方 已提交
72
		AppsCasDetails casDetails=casDetailsService.get(id);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
73 74 75 76
		
		return buildCasModelAndView(casDetails);
	}
	
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
77
	private  ModelAndView buildCasModelAndView(AppsCasDetails casDetails){
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
78 79 80 81 82 83 84 85 86 87 88 89 90
		
		_logger.debug(""+casDetails);

		WebContext.setAttribute(CasConstants.PARAMETER.ENDPOINT_CAS_DETAILS, casDetails);
		WebContext.setAttribute(WebConstants.SINGLE_SIGN_ON_APP_ID, casDetails.getId());
		return WebContext.redirect("/authz/cas/granting");
	}
	
	@RequestMapping("/authz/cas/granting")
	public ModelAndView grantingTicket(
			HttpServletRequest request,
			HttpServletResponse response){
		
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
91
		AppsCasDetails casDetails=(AppsCasDetails)WebContext.getAttribute(CasConstants.PARAMETER.ENDPOINT_CAS_DETAILS);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
92 93 94 95 96 97 98
		ServiceTicketImpl serviceTicket=new ServiceTicketImpl(WebContext.getAuthentication(),casDetails);
		
		String ticket=ticketServices.createTicket(serviceTicket);
		
		return WebContext.redirect(casDetails.getService()+"?"+CasConstants.PARAMETER.TICKET+"="+ticket);
	}
}