From f03e045710db82d37bc6bf75e97b749a85da9fcc Mon Sep 17 00:00:00 2001 From: Josh Cummings Date: Wed, 24 May 2023 10:26:59 -0600 Subject: [PATCH] Add @EnableTransactionManagement Reference Details Issue gh-13152 --- .../authorization/method-security.adoc | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/docs/modules/ROOT/pages/servlet/authorization/method-security.adoc b/docs/modules/ROOT/pages/servlet/authorization/method-security.adoc index 64bf08326f6..51949ca5344 100644 --- a/docs/modules/ROOT/pages/servlet/authorization/method-security.adoc +++ b/docs/modules/ROOT/pages/servlet/authorization/method-security.adoc @@ -44,6 +44,7 @@ Consider learning about the following use cases: * Authorizing methods with <> * Authorizing methods with <> * Integrating with <> +* Coordinating with <> * Customizing <> * Integrating with <> @@ -1222,6 +1223,43 @@ After setting up AspectJ, you can quite simply state in the `@EnableMethodSecuri And the result will be that Spring Security will publish its advisors as AspectJ advice so that they can be woven in accordingly. +[[changing-the-order]] +== Specifying Order + +As already noted, there is a Spring AOP method interceptor for each annotation, and each of these has a location in the Spring AOP advisor chain. + +Namely, the `@PreFilter` method interceptor's order is 100, ``@PreAuthorize``'s is 200, and so on. + +The reason this is important to note is that there are other AOP-based annotations like `@EnableTransactionManagement` that have an order of `Integer.MAX_VALUE`. +In other words, they are located at the end of the advisor chain by default. + +At times, it can be valuable to have other advice execute before Spring Security. +For example, if you have a method annotated with `@Transactional` and `@PostAuthorize`, you might want the transaction to still be open when `@PostAuthorize` runs so that an `AccessDeniedException` will cause a rollback. + +To get `@EnableTransactionManagement` to open a transaction before method authorization advice runs, you can set ``@EnableTransactionManagement``'s order like so: + +==== +.Java +[source,java,role="primary"] +---- +@EnableTransactionManagement(order = 0) +---- + +.Kotlin +[source,kotlin,role="secondary"] +---- +@EnableTransactionManagement(order = 0) +---- + +.Xml +[source,xml,role="secondary"] +---- + +---- +==== + +Since the earliest method interceptor (`@PreFilter`) is set to an order of 100, a setting of zero means that the transaction advice will run before all Spring Security advice. + [[authorization-expressions]] == Expressing Authorization with SpEL