From 7a8faf85d991e8b23782dc6868922715be6824ad Mon Sep 17 00:00:00 2001 From: pbborisov18 Date: Tue, 10 Oct 2023 20:10:05 +0300 Subject: [PATCH] Docs custom AuthorizationManager fix Issue gh-13967 --- .../authorization/method-security.adoc | 26 +++++++++++++------ 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/docs/modules/ROOT/pages/servlet/authorization/method-security.adoc b/docs/modules/ROOT/pages/servlet/authorization/method-security.adoc index ab2297b161..83e840d326 100644 --- a/docs/modules/ROOT/pages/servlet/authorization/method-security.adoc +++ b/docs/modules/ROOT/pages/servlet/authorization/method-security.adoc @@ -1070,7 +1070,7 @@ It also has access to the full Java language. [[custom-authorization-managers]] === Using a Custom Authorization Manager -The second way to authorize a method programmatically is two create a custom xref:servlet/authorization/architecture.adoc#_the_authorizationmanager[`AuthorizationManager`]. +The second way to authorize a method programmatically is to create a custom xref:servlet/authorization/architecture.adoc#_the_authorizationmanager[`AuthorizationManager`]. First, declare an authorization manager instance, perhaps like this one: @@ -1081,10 +1081,16 @@ Java:: [source,java,role="primary"] ---- @Component -public class MyAuthorizationManager implements AuthorizationManager { +public class MyAuthorizationManager implements AuthorizationManager, AuthorizationManager { + @Override public AuthorizationDecision check(Supplier authentication, MethodInvocation invocation) { // ... authorization logic } + + @Override + public AuthorizationDecision check(Supplier authentication, MethodInvocationResult invocation) { + // ... authorization logic + } } ---- @@ -1092,9 +1098,13 @@ Kotlin:: + [source,kotlin,role="secondary"] ---- -@Component("authz") -open class MyAuthorizationManager: AuthorizationManager { - fun check(val authentication: Supplier, val invocation: MethodInvocation): AuthorizationDecision { +@Component +class MyAuthorizationManager : AuthorizationManager, AuthorizationManager { + override fun check(authentication: Supplier, invocation: MethodInvocation): AuthorizationDecision { + // ... authorization logic + } + + override fun check(authentication: Supplier, invocation: MethodInvocationResult): AuthorizationDecision { // ... authorization logic } } @@ -1104,7 +1114,7 @@ open class MyAuthorizationManager: AuthorizationManager { Then, publish the method interceptor with a pointcut that corresponds to when you want that `AuthorizationManager` to run. For example, you could replace how `@PreAuthorize` and `@PostAuthorize` work like so: -.Only @PostAuthorize Configuration +.Only @PreAuthorize and @PostAuthorize Configuration [tabs] ====== Java:: @@ -1116,7 +1126,7 @@ Java:: class MethodSecurityConfig { @Bean @Role(BeanDefinition.ROLE_INFRASTRUCTURE) - Advisor postAuthorize(MyAuthorizationManager manager) { + Advisor preAuthorize(MyAuthorizationManager manager) { return AuthorizationManagerBeforeMethodInterceptor.preAuthorize(manager); } @@ -1157,7 +1167,7 @@ Xml:: -