cas-servlet.xml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3. Licensed to Jasig under one or more contributor license
  4. agreements. See the NOTICE file distributed with this work
  5. for additional information regarding copyright ownership.
  6. Jasig licenses this file to you under the Apache License,
  7. Version 2.0 (the "License"); you may not use this file
  8. except in compliance with the License. You may obtain a
  9. copy of the License at the following location:
  10. http://www.apache.org/licenses/LICENSE-2.0
  11. Unless required by applicable law or agreed to in writing,
  12. software distributed under the License is distributed on an
  13. "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  14. KIND, either express or implied. See the License for the
  15. specific language governing permissions and limitations
  16. under the License.
  17. -->
  18. <beans xmlns="http://www.springframework.org/schema/beans"
  19. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  20. xmlns:webflow="http://www.springframework.org/schema/webflow-config"
  21. xmlns:p="http://www.springframework.org/schema/p"
  22. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
  23. http://www.springframework.org/schema/webflow-config http://www.springframework.org/schema/webflow-config/spring-webflow-config-2.3.xsd">
  24. <import resource="spring-configuration/propertyFileConfigurer.xml"/>
  25. <!-- Theme Resolver -->
  26. <bean id="themeResolver" class="org.jasig.cas.services.web.ServiceThemeResolver"
  27. p:defaultThemeName="${cas.themeResolver.defaultThemeName}"
  28. p:argumentExtractors-ref="argumentExtractors"
  29. p:servicesManager-ref="servicesManager">
  30. <property name="mobileBrowsers">
  31. <map>
  32. <entry key=".*iPhone.*" value="iphone"/>
  33. <entry key=".*Android.*" value="iphone"/>
  34. <entry key=".*Safari.*Pre.*" value="iphone"/>
  35. <entry key=".*Nokia.*AppleWebKit.*" value="iphone"/>
  36. </map>
  37. </property>
  38. </bean>
  39. <!-- View Resolver -->
  40. <bean id="viewResolver" class="org.springframework.web.servlet.view.ResourceBundleViewResolver"
  41. p:order="0">
  42. <property name="basenames">
  43. <list>
  44. <value>${cas.viewResolver.basename}</value>
  45. <value>protocol_views</value>
  46. </list>
  47. </property>
  48. </bean>
  49. <bean id="xmlViewResolver" class="org.springframework.web.servlet.view.XmlViewResolver"
  50. p:order="1"
  51. p:location="/WEB-INF/view/views.xml"
  52. />
  53. <!-- Locale Resolver -->
  54. <bean id="localeResolver" class="org.springframework.web.servlet.i18n.CookieLocaleResolver"/>
  55. <bean id="localeChangeInterceptor" class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor"/>
  56. <bean id="urlBasedViewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver"
  57. p:viewClass="org.springframework.web.servlet.view.InternalResourceView"
  58. p:prefix="/WEB-INF/view/jsp/"
  59. p:suffix=".jsp"
  60. p:order="2"/>
  61. <bean id="errorHandlerResolver" class="org.jasig.cas.web.FlowExecutionExceptionResolver"/>
  62. <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
  63. <bean
  64. id="handlerMappingC"
  65. class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
  66. <property name="mappings">
  67. <props>
  68. <prop key="/logout">logoutController</prop>
  69. <prop key="/serviceValidate">serviceValidateController</prop>
  70. <prop key="/validate">legacyValidateController</prop>
  71. <prop key="/proxy">proxyController</prop>
  72. <prop key="/proxyValidate">proxyValidateController</prop>
  73. <prop key="/samlValidate">samlValidateController</prop>
  74. <prop key="/services/add.html">addRegisteredServiceSimpleFormController</prop>
  75. <prop key="/services/edit.html">editRegisteredServiceSimpleFormController</prop>
  76. <prop key="/services/loggedOut.html">serviceLogoutViewController</prop>
  77. <prop key="/services/viewStatistics.html">viewStatisticsController</prop>
  78. <prop key="/services/*">manageRegisteredServicesMultiActionController</prop>
  79. <prop key="/openid/*">openIdProviderController</prop>
  80. <prop key="/authorizationFailure.html">passThroughController</prop>
  81. <prop key="/403.html">passThroughController</prop>
  82. <prop key="/status">healthCheckController</prop>
  83. </props>
  84. </property>
  85. <property
  86. name="alwaysUseFullPath" value="true"/>
  87. <!--
  88. uncomment this to enable sending PageRequest events.
  89. <property
  90. name="interceptors">
  91. <list>
  92. <ref bean="pageRequestHandlerInterceptorAdapter" />
  93. </list>
  94. </property>
  95. -->
  96. </bean>
  97. <bean id="passThroughController" class="org.springframework.web.servlet.mvc.UrlFilenameViewController"/>
  98. <bean
  99. id="openIdProviderController"
  100. class="org.jasig.cas.web.OpenIdProviderController"
  101. p:loginUrl="${cas.securityContext.casProcessingFilterEntryPoint.loginUrl}"/>
  102. <bean
  103. id="serviceLogoutViewController"
  104. class="org.springframework.web.servlet.mvc.ParameterizableViewController"
  105. p:viewName="serviceLogoutView"/>
  106. <bean class="org.springframework.webflow.mvc.servlet.FlowHandlerMapping" p:flowRegistry-ref="flowRegistry"
  107. p:order="2">
  108. <property name="interceptors">
  109. <ref local="localeChangeInterceptor"/>
  110. </property>
  111. </bean>
  112. <bean class="org.springframework.webflow.mvc.servlet.FlowHandlerAdapter"
  113. p:flowExecutor-ref="flowExecutor"
  114. p:flowUrlHandler-ref="flowUrlHandler"/>
  115. <bean id="flowUrlHandler" class="org.jasig.cas.web.flow.CasDefaultFlowUrlHandler"/>
  116. <webflow:flow-executor id="flowExecutor" flow-registry="flowRegistry">
  117. <webflow:flow-execution-attributes>
  118. <webflow:always-redirect-on-pause value="false"/>
  119. <webflow:redirect-in-same-state value="false" />
  120. </webflow:flow-execution-attributes>
  121. <webflow:flow-execution-listeners>
  122. <webflow:listener ref="terminateWebSessionListener" />
  123. </webflow:flow-execution-listeners>
  124. </webflow:flow-executor>
  125. <webflow:flow-registry id="flowRegistry" flow-builder-services="builder">
  126. <webflow:flow-location path="/WEB-INF/login-webflow.xml" id="login"/>
  127. </webflow:flow-registry>
  128. <webflow:flow-builder-services id="builder" view-factory-creator="viewFactoryCreator"
  129. expression-parser="expressionParser"/>
  130. <bean id="terminateWebSessionListener" class="org.jasig.cas.web.flow.TerminateWebSessionListener"
  131. p:serviceManagerUrl="${cas.securityContext.serviceProperties.service}" p:timeToDieInSeconds="18000" />
  132. <bean id="expressionParser" class="org.springframework.webflow.expression.WebFlowOgnlExpressionParser"/>
  133. <bean id="viewFactoryCreator" class="org.springframework.webflow.mvc.builder.MvcViewFactoryCreator">
  134. <property name="viewResolvers">
  135. <list>
  136. <ref local="viewResolver"/>
  137. </list>
  138. </property>
  139. </bean>
  140. <bean id="proxyValidateController" class="org.jasig.cas.web.ServiceValidateController"
  141. p:centralAuthenticationService-ref="centralAuthenticationService"
  142. p:proxyHandler-ref="proxy20Handler"
  143. p:argumentExtractor-ref="casArgumentExtractor"/>
  144. <bean id="serviceValidateController" class="org.jasig.cas.web.ServiceValidateController"
  145. p:validationSpecificationClass="org.jasig.cas.validation.Cas20WithoutProxyingValidationSpecification"
  146. p:centralAuthenticationService-ref="centralAuthenticationService"
  147. p:proxyHandler-ref="proxy20Handler"
  148. p:argumentExtractor-ref="casArgumentExtractor"/>
  149. <bean id="samlValidateController" class="org.jasig.cas.web.ServiceValidateController"
  150. p:validationSpecificationClass="org.jasig.cas.validation.Cas20WithoutProxyingValidationSpecification"
  151. p:centralAuthenticationService-ref="centralAuthenticationService"
  152. p:proxyHandler-ref="proxy20Handler"
  153. p:argumentExtractor-ref="samlArgumentExtractor"
  154. p:successView="casSamlServiceSuccessView"
  155. p:failureView="casSamlServiceFailureView"/>
  156. <bean id="legacyValidateController" class="org.jasig.cas.web.ServiceValidateController"
  157. p:proxyHandler-ref="proxy10Handler"
  158. p:successView="cas1ServiceSuccessView"
  159. p:failureView="cas1ServiceFailureView"
  160. p:validationSpecificationClass="org.jasig.cas.validation.Cas10ProtocolValidationSpecification"
  161. p:centralAuthenticationService-ref="centralAuthenticationService"
  162. p:argumentExtractor-ref="casArgumentExtractor"/>
  163. <bean id="proxyController" class="org.jasig.cas.web.ProxyController"
  164. p:centralAuthenticationService-ref="centralAuthenticationService"/>
  165. <bean id="viewStatisticsController" class="org.jasig.cas.web.StatisticsController"
  166. p:casTicketSuffix="${host.name}">
  167. <constructor-arg index="0" ref="ticketRegistry"/>
  168. </bean>
  169. <bean id="logoutController" class="org.jasig.cas.web.LogoutController"
  170. p:centralAuthenticationService-ref="centralAuthenticationService"
  171. p:logoutView="casLogoutView"
  172. p:warnCookieGenerator-ref="warnCookieGenerator"
  173. p:ticketGrantingTicketCookieGenerator-ref="ticketGrantingTicketCookieGenerator"
  174. p:servicesManager-ref="servicesManager"
  175. p:followServiceRedirects="${cas.logout.followServiceRedirects:true}"/>
  176. <bean id="healthCheckController" class="org.jasig.cas.web.HealthCheckController"
  177. p:healthCheckMonitor-ref="healthCheckMonitor"/>
  178. <bean id="initialFlowSetupAction" class="org.jasig.cas.web.flow.InitialFlowSetupAction"
  179. p:argumentExtractors-ref="argumentExtractors"
  180. p:warnCookieGenerator-ref="warnCookieGenerator"
  181. p:ticketGrantingTicketCookieGenerator-ref="ticketGrantingTicketCookieGenerator"/>
  182. <bean id="authenticationViaFormAction" class="org.jasig.cas.web.flow.AuthenticationViaFormAction"
  183. p:centralAuthenticationService-ref="centralAuthenticationService"
  184. p:warnCookieGenerator-ref="warnCookieGenerator"/>
  185. <bean id="generateServiceTicketAction" class="org.jasig.cas.web.flow.GenerateServiceTicketAction"
  186. p:centralAuthenticationService-ref="centralAuthenticationService"/>
  187. <bean id="sendTicketGrantingTicketAction" class="org.jasig.cas.web.flow.SendTicketGrantingTicketAction"
  188. p:centralAuthenticationService-ref="centralAuthenticationService"
  189. p:ticketGrantingTicketCookieGenerator-ref="ticketGrantingTicketCookieGenerator"/>
  190. <bean id="gatewayServicesManagementCheck" class="org.jasig.cas.web.flow.GatewayServicesManagementCheck">
  191. <constructor-arg index="0" ref="servicesManager"/>
  192. </bean>
  193. <bean id="serviceAuthorizationCheck" class="org.jasig.cas.web.flow.ServiceAuthorizationCheck">
  194. <constructor-arg index="0" ref="servicesManager"/>
  195. </bean>
  196. <bean id="generateLoginTicketAction" class="org.jasig.cas.web.flow.GenerateLoginTicketAction"
  197. p:ticketIdGenerator-ref="loginTicketUniqueIdGenerator"/>
  198. <bean id="addRegisteredServiceSimpleFormController"
  199. class="org.jasig.cas.services.web.RegisteredServiceSimpleFormController"
  200. p:formView="addServiceView"
  201. p:successView="addServiceView"
  202. p:commandName="registeredService"
  203. p:validator-ref="registeredServiceValidator"
  204. p:sessionForm="true">
  205. <constructor-arg index="0" ref="servicesManager"/>
  206. <constructor-arg index="1" ref="attributeRepository"/>
  207. </bean>
  208. <bean id="editRegisteredServiceSimpleFormController"
  209. class="org.jasig.cas.services.web.RegisteredServiceSimpleFormController"
  210. p:formView="editServiceView"
  211. p:successView="editServiceView"
  212. p:commandName="registeredService"
  213. p:validator-ref="registeredServiceValidator"
  214. p:sessionForm="false">
  215. <constructor-arg index="0" ref="servicesManager"/>
  216. <constructor-arg index="1" ref="attributeRepository"/>
  217. </bean>
  218. <bean id="registeredServiceValidator" class="org.jasig.cas.services.web.support.RegisteredServiceValidator"
  219. p:servicesManager-ref="servicesManager"
  220. p:personAttributeDao-ref="attributeRepository" />
  221. <bean id="manageRegisteredServicesMultiActionController"
  222. class="org.jasig.cas.services.web.ManageRegisteredServicesMultiActionController">
  223. <constructor-arg index="0" ref="servicesManager"/>
  224. <constructor-arg index="1" value="${cas.securityContext.serviceProperties.service}"/>
  225. </bean>
  226. <bean id="messageInterpolator" class="org.jasig.cas.util.SpringAwareMessageMessageInterpolator"/>
  227. <bean id="credentialsValidator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean"
  228. p:messageInterpolator-ref="messageInterpolator"/>
  229. </beans>