12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- [[data]]
- = Spring Data Integration
- Spring Security provides Spring Data integration that allows referring to the current user within your queries.
- It is not only useful but necessary to include the user in the queries to support paged results since filtering the results afterwards would not scale.
- [[data-configuration]]
- == Spring Data & Spring Security Configuration
- To use this support, add `org.springframework.security:spring-security-data` dependency and provide a bean of type `SecurityEvaluationContextExtension`:
- ====
- .Java
- [source,java,role="primary"]
- ----
- @Bean
- public SecurityEvaluationContextExtension securityEvaluationContextExtension() {
- return new SecurityEvaluationContextExtension();
- }
- ----
- .Kotlin
- [source,kotlin,role="secondary"]
- ----
- @Bean
- fun securityEvaluationContextExtension(): SecurityEvaluationContextExtension {
- return SecurityEvaluationContextExtension()
- }
- ----
- ====
- In XML Configuration, this would look like:
- ====
- [source,xml]
- ----
- <bean class="org.springframework.security.data.repository.query.SecurityEvaluationContextExtension"/>
- ----
- ====
- [[data-query]]
- == Security Expressions within @Query
- Now you can use Spring Security within your queries:
- ====
- .Java
- [source,java,role="primary"]
- ----
- @Repository
- public interface MessageRepository extends PagingAndSortingRepository<Message,Long> {
- @Query("select m from Message m where m.to.id = ?#{ principal?.id }")
- Page<Message> findInbox(Pageable pageable);
- }
- ----
- .Kotlin
- [source,kotlin,role="secondary"]
- ----
- @Repository
- interface MessageRepository : PagingAndSortingRepository<Message,Long> {
- @Query("select m from Message m where m.to.id = ?#{ principal?.id }")
- fun findInbox(pageable: Pageable): Page<Message>
- }
- ----
- ====
- This checks to see if the `Authentication.getPrincipal().getId()` is equal to the recipient of the `Message`.
- Note that this example assumes you have customized the principal to be an Object that has an id property.
- By exposing the `SecurityEvaluationContextExtension` bean, all of the xref:servlet/authorization/expression-based.adoc#common-expressions[Common Security Expressions] are available within the Query.
|