Michael Hanl | ca740d7 | 2015-06-16 10:04:58 +0200 | [diff] [blame] | 1 | <?xml version="1.0" encoding="UTF-8"?> |
| 2 | <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
margaretha | 14503cd | 2017-09-08 15:35:24 +0200 | [diff] [blame] | 3 | xmlns:p="http://www.springframework.org/schema/p" |
| 4 | xmlns:util="http://www.springframework.org/schema/util" |
| 5 | xmlns:aop="http://www.springframework.org/schema/aop" |
| 6 | xmlns:tx="http://www.springframework.org/schema/tx" |
| 7 | xmlns="http://www.springframework.org/schema/beans" |
| 8 | xmlns:context="http://www.springframework.org/schema/context" |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 9 | xmlns:cache="http://www.springframework.org/schema/cache" |
| 10 | xsi:schemaLocation="http://www.springframework.org/schema/beans |
| 11 | http://www.springframework.org/schema/beans/spring-beans-4.0.xsd |
| 12 | http://www.springframework.org/schema/tx |
| 13 | http://www.springframework.org/schema/tx/spring-tx-4.0.xsd |
| 14 | http://www.springframework.org/schema/aop |
| 15 | http://www.springframework.org/schema/aop/spring-aop-4.0.xsd |
| 16 | http://www.springframework.org/schema/context |
| 17 | http://www.springframework.org/schema/context/spring-context-4.0.xsd |
| 18 | http://www.springframework.org/schema/util |
| 19 | http://www.springframework.org/schema/util/spring-util-4.0.xsd"> |
| 20 | |
| 21 | <context:component-scan base-package="de.ids_mannheim.korap" /> |
| 22 | <context:annotation-config /> |
| 23 | |
margaretha | ade7d4a | 2017-07-20 19:53:35 +0200 | [diff] [blame] | 24 | <!-- <bean id="test" class="de.ids_mannheim.korap.web.Test"> |
| 25 | <property name="config" ref="kustvakt_config" /> |
| 26 | </bean> --> |
| 27 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 28 | <bean id="props" |
| 29 | class="org.springframework.beans.factory.config.PropertiesFactoryBean"> |
| 30 | <property name="ignoreResourceNotFound" value="true" /> |
| 31 | <property name="locations"> |
| 32 | <array> |
| 33 | <value>classpath:kustvakt.conf</value> |
| 34 | <value>file:./kustvakt.conf</value> |
| 35 | </array> |
| 36 | </property> |
| 37 | </bean> |
| 38 | |
| 39 | <bean id="placeholders" |
| 40 | class="org.springframework.context.support.PropertySourcesPlaceholderConfigurer"> |
| 41 | <property name="ignoreResourceNotFound" value="true" /> |
| 42 | <property name="locations"> |
| 43 | <array> |
| 44 | <value>classpath:jdbc.properties</value> |
margaretha | ea68a0a | 2017-09-21 03:09:49 +0200 | [diff] [blame] | 45 | <value>file:./jdbc.properties</value> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 46 | <value>classpath:hibernate.properties</value> |
margaretha | ade7d4a | 2017-07-20 19:53:35 +0200 | [diff] [blame] | 47 | <value>classpath:kustvakt.conf</value> |
margaretha | 14503cd | 2017-09-08 15:35:24 +0200 | [diff] [blame] | 48 | <value>file:./kustvakt.conf</value> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 49 | </array> |
| 50 | </property> |
| 51 | </bean> |
| 52 | |
| 53 | <bean id='cacheManager' class='org.springframework.cache.ehcache.EhCacheCacheManager' |
| 54 | p:cacheManager-ref='ehcache' /> |
| 55 | |
| 56 | <bean id='ehcache' |
| 57 | class='org.springframework.cache.ehcache.EhCacheManagerFactoryBean' |
| 58 | p:configLocation='classpath:ehcache.xml' p:shared='true' /> |
| 59 | |
| 60 | <!-- props are injected from default-config.xml --> |
| 61 | <bean id="kustvakt_config" class="de.ids_mannheim.korap.config.KustvaktConfiguration"> |
margaretha | f68daa6 | 2017-09-21 02:11:24 +0200 | [diff] [blame] | 62 | <constructor-arg name="properties" ref="props" /> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 63 | </bean> |
| 64 | |
| 65 | <!--class="org.apache.commons.dbcp2.BasicDataSource" --> |
| 66 | <!-- org.springframework.jdbc.datasource.SingleConnectionDataSource --> |
| 67 | <bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource" |
| 68 | lazy-init="true"> |
| 69 | <property name="driverClassName" value="${jdbc.driverClassName}" /> |
| 70 | <property name="url" value="${jdbc.url}" /> |
| 71 | <property name="username" value="${jdbc.username}" /> |
| 72 | <property name="password" value="${jdbc.password}" /> |
| 73 | <!-- relevant for single connection datasource and sqlite --> |
| 74 | <!-- <property name="suppressClose"> <value>true</value> </property> --> |
| 75 | <!--<property name="initialSize" value="2"/> --> |
| 76 | <property name="maxTotal" value="4" /> |
| 77 | <property name="maxIdle" value="2" /> |
| 78 | <property name="minIdle" value="1" /> |
| 79 | <property name="maxWaitMillis" value="15000" /> |
| 80 | <!--<property name="poolPreparedStatements" value="true"/> --> |
| 81 | </bean> |
| 82 | |
| 83 | <bean id="sqliteDataSource" |
| 84 | class="org.springframework.jdbc.datasource.SingleConnectionDataSource" |
| 85 | lazy-init="true"> |
| 86 | <property name="driverClassName" value="${jdbc.driverClassName}" /> |
| 87 | <property name="url" value="${jdbc.url}" /> |
| 88 | <property name="username" value="${jdbc.username}" /> |
| 89 | <property name="password" value="${jdbc.password}" /> |
| 90 | <!-- relevant for single connection datasource and sqlite --> |
| 91 | <property name="suppressClose"> |
| 92 | <value>true</value> |
| 93 | </property> |
| 94 | <!--<property name="initialSize" value="2"/> --> |
| 95 | <!--<property name="poolPreparedStatements" value="true"/> --> |
| 96 | </bean> |
| 97 | |
| 98 | <!-- to configure database for sqlite, mysql, etc. migrations --> |
| 99 | <bean id="flyway" class="org.flywaydb.core.Flyway" init-method="migrate"> |
margaretha | f6d5a82 | 2017-10-19 19:51:20 +0200 | [diff] [blame] | 100 | <property name="baselineOnMigrate" value="true" /> |
margaretha | ecbe72d | 2017-07-26 17:13:32 +0200 | [diff] [blame] | 101 | <!-- <property name="validateOnMigrate" value="false" /> --> |
| 102 | <!-- <property name="cleanOnValidationError" value="true" /> --> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 103 | <property name="locations" value="${jdbc.schemaPath}" /> |
margaretha | 894a7d7 | 2017-11-08 19:24:20 +0100 | [diff] [blame] | 104 | <!-- <property name="dataSource" ref="dataSource" /> --> |
| 105 | <property name="dataSource" ref="sqliteDataSource" /> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 106 | </bean> |
margaretha | f18298b | 2017-09-14 22:14:32 +0200 | [diff] [blame] | 107 | |
| 108 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 109 | <bean id="kustvakt_db" class="de.ids_mannheim.korap.handlers.JDBCClient"> |
| 110 | <constructor-arg index="0" ref="dataSource" /> |
| 111 | <!-- deprecated property --> |
| 112 | <property name="database" value="${jdbc.database}" /> |
| 113 | </bean> |
| 114 | |
| 115 | <bean id="entityManagerFactory" |
| 116 | class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> |
margaretha | 894a7d7 | 2017-11-08 19:24:20 +0100 | [diff] [blame] | 117 | <!-- <property name="dataSource" ref="dataSource" /> --> |
| 118 | <property name="dataSource" ref="sqliteDataSource" /> |
| 119 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 120 | <property name="packagesToScan" value="de.ids_mannheim.korap.entity" /> |
| 121 | <property name="jpaVendorAdapter"> |
| 122 | <bean id="jpaVendorAdapter" |
| 123 | class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> |
| 124 | <property name="databasePlatform" value="${hibernate.dialect}" /> |
| 125 | </bean> |
| 126 | </property> |
| 127 | <property name="jpaProperties"> |
| 128 | <props> |
| 129 | <prop key="hibernate.dialect">${hibernate.dialect}</prop> |
| 130 | <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop> |
| 131 | <prop key="hibernate.show_sql">${hibernate.show_sql}</prop> |
| 132 | <prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop> |
| 133 | <prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache} |
| 134 | </prop> |
| 135 | <prop key="hibernate.cache.provider_class">${hibernate.cache.provider}</prop> |
| 136 | <prop key="hibernate.cache.region.factory_class">${hibernate.cache.region.factory}</prop> |
| 137 | <!-- <prop key="net.sf.ehcache.configurationResourceName">classpath:ehcache.xml</prop> --> |
| 138 | </props> |
| 139 | </property> |
| 140 | </bean> |
| 141 | |
| 142 | <tx:annotation-driven proxy-target-class="true" |
| 143 | transaction-manager="transactionManager" /> |
margaretha | 894a7d7 | 2017-11-08 19:24:20 +0100 | [diff] [blame] | 144 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 145 | <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> |
| 146 | <property name="entityManagerFactory" ref="entityManagerFactory" /> |
| 147 | </bean> |
| 148 | |
| 149 | <bean id="transactionTemplate" |
| 150 | class="org.springframework.transaction.support.TransactionTemplate"> |
| 151 | <constructor-arg ref="transactionManager" /> |
| 152 | </bean> |
| 153 | |
margaretha | ade7d4a | 2017-07-20 19:53:35 +0200 | [diff] [blame] | 154 | <!-- Data access objects --> |
| 155 | <bean id="resourceDao" class="de.ids_mannheim.korap.dao.ResourceDao"/> |
| 156 | <!-- <bean id="annotationDao" class="de.ids_mannheim.korap.dao.AnnotationDao"/> --> |
| 157 | |
| 158 | <!-- Krill --> |
| 159 | <bean id="search_krill" class="de.ids_mannheim.korap.web.SearchKrill"> |
| 160 | <constructor-arg value="${krill.indexDir}"/> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 161 | </bean> |
| 162 | |
| 163 | <bean id="kustvakt_auditing" class="de.ids_mannheim.korap.handlers.JDBCAuditing"> |
| 164 | <constructor-arg ref="kustvakt_db" /> |
| 165 | </bean> |
| 166 | |
margaretha | 894a7d7 | 2017-11-08 19:24:20 +0100 | [diff] [blame] | 167 | <bean id="kustvakt_response" |
| 168 | class="de.ids_mannheim.korap.web.utils.KustvaktResponseHandler"> |
| 169 | <constructor-arg index="0" name="iface" ref="kustvakt_auditing"/> |
| 170 | </bean> |
| 171 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 172 | <bean id="kustvakt_userdb" class="de.ids_mannheim.korap.handlers.EntityDao"> |
| 173 | <constructor-arg ref="kustvakt_db" /> |
| 174 | </bean> |
| 175 | |
| 176 | <bean id="kustvakt_admindb" class="de.ids_mannheim.korap.handlers.AdminDao"> |
| 177 | <constructor-arg ref="kustvakt_db" /> |
| 178 | </bean> |
| 179 | |
| 180 | <bean id="resource_provider" class="de.ids_mannheim.korap.handlers.ResourceDao"> |
| 181 | <constructor-arg ref="kustvakt_db" /> |
| 182 | </bean> |
| 183 | |
| 184 | <bean id="document_provider" class="de.ids_mannheim.korap.handlers.DocumentDao"> |
| 185 | <constructor-arg ref="kustvakt_db" /> |
| 186 | </bean> |
| 187 | |
| 188 | <bean id="kustvakt_policies" class="de.ids_mannheim.korap.security.ac.PolicyDao"> |
| 189 | <constructor-arg ref="kustvakt_db" /> |
| 190 | </bean> |
| 191 | |
| 192 | <bean name="kustvakt_encryption" |
| 193 | class="de.ids_mannheim.korap.interfaces.defaults.KustvaktEncryption"> |
| 194 | <constructor-arg ref="kustvakt_config" /> |
| 195 | </bean> |
| 196 | |
| 197 | <!-- authentication providers to use --> |
margaretha | 4de4119 | 2017-11-15 11:47:11 +0100 | [diff] [blame^] | 198 | <!-- <bean id="api_auth" class="de.ids_mannheim.korap.authentication.APIAuthentication"> |
| 199 | <constructor-arg type="de.ids_mannheim.korap.config.KustvaktConfiguration" |
| 200 | ref="kustvakt_config" /> |
| 201 | </bean> --> |
| 202 | |
| 203 | <bean id="ldap_auth" class="de.ids_mannheim.korap.authentication.LdapAuth3"> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 204 | <constructor-arg type="de.ids_mannheim.korap.config.KustvaktConfiguration" |
| 205 | ref="kustvakt_config" /> |
| 206 | </bean> |
| 207 | |
| 208 | <bean id="openid_auth" |
margaretha | 139d0f7 | 2017-11-14 18:56:22 +0100 | [diff] [blame] | 209 | class="de.ids_mannheim.korap.authentication.OpenIDconnectAuthentication"> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 210 | <constructor-arg type="de.ids_mannheim.korap.config.KustvaktConfiguration" |
| 211 | ref="kustvakt_config" /> |
| 212 | <constructor-arg |
| 213 | type="de.ids_mannheim.korap.interfaces.db.PersistenceClient" ref="kustvakt_db" /> |
| 214 | </bean> |
| 215 | |
margaretha | 139d0f7 | 2017-11-14 18:56:22 +0100 | [diff] [blame] | 216 | <bean id="basic_auth" class="de.ids_mannheim.korap.authentication.BasicHttpAuth" /> |
Michael Hanl | e4fc775 | 2016-02-17 11:41:18 +0100 | [diff] [blame] | 217 | |
| 218 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 219 | <bean id="session_auth" |
margaretha | 139d0f7 | 2017-11-14 18:56:22 +0100 | [diff] [blame] | 220 | class="de.ids_mannheim.korap.authentication.SessionAuthentication"> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 221 | <constructor-arg type="de.ids_mannheim.korap.config.KustvaktConfiguration" |
| 222 | ref="kustvakt_config" /> |
| 223 | <constructor-arg type="de.ids_mannheim.korap.interfaces.EncryptionIface" |
| 224 | ref="kustvakt_encryption" /> |
| 225 | </bean> |
Michael Hanl | ca740d7 | 2015-06-16 10:04:58 +0200 | [diff] [blame] | 226 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 227 | <util:list id="kustvakt_authproviders" |
| 228 | value-type="de.ids_mannheim.korap.interfaces.AuthenticationIface"> |
| 229 | <ref bean="basic_auth" /> |
margaretha | 4de4119 | 2017-11-15 11:47:11 +0100 | [diff] [blame^] | 230 | <ref bean="ldap_auth" /> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 231 | <ref bean="session_auth" /> |
margaretha | 4de4119 | 2017-11-15 11:47:11 +0100 | [diff] [blame^] | 232 | <!-- <ref bean="api_auth" /> --> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 233 | <ref bean="openid_auth" /> |
| 234 | </util:list> |
Michael Hanl | 72c7b83 | 2015-09-03 08:42:15 +0200 | [diff] [blame] | 235 | |
| 236 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 237 | <bean id="userdata_details" class="de.ids_mannheim.korap.handlers.UserDetailsDao"> |
| 238 | <constructor-arg ref="kustvakt_db" /> |
| 239 | </bean> |
Michael Hanl | 72c7b83 | 2015-09-03 08:42:15 +0200 | [diff] [blame] | 240 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 241 | <bean id="userdata_settings" class="de.ids_mannheim.korap.handlers.UserSettingsDao"> |
| 242 | <constructor-arg ref="kustvakt_db" /> |
| 243 | </bean> |
| 244 | |
| 245 | <util:list id="kustvakt_userdata" |
| 246 | value-type="de.ids_mannheim.korap.interfaces.db.UserdataDbIface"> |
| 247 | <ref bean="userdata_details" /> |
| 248 | <ref bean="userdata_settings" /> |
| 249 | </util:list> |
Michael Hanl | 72c7b83 | 2015-09-03 08:42:15 +0200 | [diff] [blame] | 250 | |
Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 251 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 252 | <util:list id="kustvakt_resources" |
| 253 | value-type="de.ids_mannheim.korap.interfaces.db.ResourceOperationIface"> |
| 254 | <ref bean="document_provider" /> |
| 255 | <ref bean="resource_provider" /> |
| 256 | </util:list> |
Michael Hanl | f8fcc7a | 2016-06-03 17:41:07 +0200 | [diff] [blame] | 257 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 258 | <!-- specify type for constructor argument --> |
| 259 | <bean id="kustvakt_authenticationmanager" |
margaretha | 139d0f7 | 2017-11-14 18:56:22 +0100 | [diff] [blame] | 260 | class="de.ids_mannheim.korap.authentication.KustvaktAuthenticationManager"> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 261 | <constructor-arg |
| 262 | type="de.ids_mannheim.korap.interfaces.db.EntityHandlerIface" ref="kustvakt_userdb" /> |
| 263 | <constructor-arg |
| 264 | type="de.ids_mannheim.korap.interfaces.db.AdminHandlerIface" ref="kustvakt_admindb" /> |
| 265 | <constructor-arg type="de.ids_mannheim.korap.interfaces.EncryptionIface" |
| 266 | ref="kustvakt_encryption" /> |
| 267 | <constructor-arg ref="kustvakt_config" /> |
| 268 | <constructor-arg type="de.ids_mannheim.korap.interfaces.db.AuditingIface" |
| 269 | ref="kustvakt_auditing" /> |
| 270 | <constructor-arg ref="kustvakt_userdata" /> |
| 271 | <!-- inject authentication providers to use --> |
| 272 | <property name="providers" ref="kustvakt_authproviders" /> |
| 273 | </bean> |
Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 274 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 275 | <!-- todo: if db interfaces not loaded via spring, does transaction even |
| 276 | work then? --> |
| 277 | <!-- the transactional advice (i.e. what 'happens'; see the <aop:advisor/> |
| 278 | bean below) --> |
| 279 | <tx:advice id="txAdvice" transaction-manager="txManager"> |
| 280 | <!-- the transactional semantics... --> |
| 281 | <tx:attributes> |
| 282 | <!-- all methods starting with 'get' are read-only --> |
| 283 | <tx:method name="get*" read-only="true" rollback-for="KorAPException" /> |
| 284 | <!-- other methods use the default transaction settings (see below) --> |
| 285 | <tx:method name="*" rollback-for="KorAPException" /> |
| 286 | </tx:attributes> |
| 287 | </tx:advice> |
Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 288 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 289 | <!-- ensure that the above transactional advice runs for any execution of |
| 290 | an operation defined by the service interface --> |
| 291 | <aop:config> |
| 292 | <aop:pointcut id="service" |
| 293 | expression="execution(* de.ids_mannheim.korap.interfaces.db.*.*(..))" /> |
| 294 | <aop:advisor advice-ref="txAdvice" pointcut-ref="service" /> |
| 295 | </aop:config> |
Michael Hanl | f8fcc7a | 2016-06-03 17:41:07 +0200 | [diff] [blame] | 296 | |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 297 | <!-- similarly, don't forget the PlatformTransactionManager --> |
| 298 | <bean id="txManager" |
| 299 | class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> |
margaretha | 894a7d7 | 2017-11-08 19:24:20 +0100 | [diff] [blame] | 300 | <!-- <property name="dataSource" ref="dataSource" /> --> |
| 301 | <property name="dataSource" ref="sqliteDataSource" /> |
margaretha | 543f200 | 2017-07-14 00:27:15 +0200 | [diff] [blame] | 302 | </bean> |
margaretha | f68daa6 | 2017-09-21 02:11:24 +0200 | [diff] [blame] | 303 | |
Michael Hanl | ca740d7 | 2015-06-16 10:04:58 +0200 | [diff] [blame] | 304 | </beans> |