Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in / Register
Toggle navigation
S
spring-boot
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
DEMO
spring-boot
Commits
6100b3e8
Commit
6100b3e8
authored
Jan 13, 2017
by
Andy Wilkinson
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch '1.5.x'
parents
1d4cee94
66915a45
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
58 additions
and
6 deletions
+58
-6
OAuth2MethodSecurityConfiguration.java
...rity/oauth2/method/OAuth2MethodSecurityConfiguration.java
+1
-6
OAuth2AutoConfigurationTests.java
...nfigure/security/oauth2/OAuth2AutoConfigurationTests.java
+57
-0
No files found.
spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/security/oauth2/method/OAuth2MethodSecurityConfiguration.java
View file @
6100b3e8
/*
* Copyright 2012-201
5
the original author or authors.
* Copyright 2012-201
7
the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
...
...
@@ -26,7 +26,6 @@ import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import
org.springframework.context.ApplicationContext
;
import
org.springframework.context.ApplicationContextAware
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.security.access.PermissionEvaluator
;
import
org.springframework.security.access.expression.method.DefaultMethodSecurityExpressionHandler
;
import
org.springframework.security.authentication.AuthenticationTrustResolver
;
import
org.springframework.security.config.annotation.method.configuration.GlobalMethodSecurityConfiguration
;
...
...
@@ -99,10 +98,6 @@ public class OAuth2MethodSecurityConfiguration
if
(
trustResolver
!=
null
)
{
handler
.
setTrustResolver
(
trustResolver
);
}
PermissionEvaluator
permissions
=
findInContext
(
PermissionEvaluator
.
class
);
if
(
permissions
!=
null
)
{
handler
.
setPermissionEvaluator
(
permissions
);
}
handler
.
setExpressionParser
(
bean
.
getExpressionParser
());
return
handler
;
}
...
...
spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/security/oauth2/OAuth2AutoConfigurationTests.java
View file @
6100b3e8
...
...
@@ -51,12 +51,15 @@ import org.springframework.http.HttpMethod;
import
org.springframework.http.HttpStatus
;
import
org.springframework.http.RequestEntity
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.security.access.PermissionEvaluator
;
import
org.springframework.security.access.annotation.Jsr250MethodSecurityMetadataSource
;
import
org.springframework.security.access.annotation.SecuredAnnotationSecurityMetadataSource
;
import
org.springframework.security.access.expression.method.MethodSecurityExpressionHandler
;
import
org.springframework.security.access.hierarchicalroles.RoleHierarchy
;
import
org.springframework.security.access.method.DelegatingMethodSecurityMetadataSource
;
import
org.springframework.security.access.method.MethodSecurityMetadataSource
;
import
org.springframework.security.access.prepost.PreAuthorize
;
import
org.springframework.security.access.prepost.PreInvocationAuthorizationAdvice
;
import
org.springframework.security.access.prepost.PrePostAnnotationSecurityMetadataSource
;
import
org.springframework.security.authentication.AuthenticationManager
;
import
org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder
;
...
...
@@ -98,6 +101,7 @@ import org.springframework.web.bind.annotation.PostMapping;
import
org.springframework.web.bind.annotation.RestController
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
import
static
org
.
mockito
.
Mockito
.
mock
;
/**
* Verify Spring Security OAuth2 auto-configuration secures end points properly, accepts
...
...
@@ -143,6 +147,39 @@ public class OAuth2AutoConfigurationTests {
.
isEmpty
();
}
@Test
public
void
methodSecurityExpressionHandlerIsConfiguredWithRoleHierarchyFromTheContext
()
{
this
.
context
=
new
AnnotationConfigEmbeddedWebApplicationContext
();
this
.
context
.
register
(
RoleHierarchyConfiguration
.
class
,
AuthorizationAndResourceServerConfiguration
.
class
,
MinimalSecureWebApplication
.
class
);
this
.
context
.
refresh
();
PreInvocationAuthorizationAdvice
advice
=
this
.
context
.
getBean
(
PreInvocationAuthorizationAdvice
.
class
);
MethodSecurityExpressionHandler
expressionHandler
=
(
MethodSecurityExpressionHandler
)
ReflectionTestUtils
.
getField
(
advice
,
"expressionHandler"
);
RoleHierarchy
roleHierarchy
=
(
RoleHierarchy
)
ReflectionTestUtils
.
getField
(
expressionHandler
,
"roleHierarchy"
);
assertThat
(
roleHierarchy
).
isSameAs
(
this
.
context
.
getBean
(
RoleHierarchy
.
class
));
}
@Test
public
void
methodSecurityExpressionHandlerIsConfiguredWithPermissionEvaluatorFromTheContext
()
{
this
.
context
=
new
AnnotationConfigEmbeddedWebApplicationContext
();
this
.
context
.
register
(
PermissionEvaluatorConfiguration
.
class
,
AuthorizationAndResourceServerConfiguration
.
class
,
MinimalSecureWebApplication
.
class
);
this
.
context
.
refresh
();
PreInvocationAuthorizationAdvice
advice
=
this
.
context
.
getBean
(
PreInvocationAuthorizationAdvice
.
class
);
MethodSecurityExpressionHandler
expressionHandler
=
(
MethodSecurityExpressionHandler
)
ReflectionTestUtils
.
getField
(
advice
,
"expressionHandler"
);
PermissionEvaluator
permissionEvaluator
=
(
PermissionEvaluator
)
ReflectionTestUtils
.
getField
(
expressionHandler
,
"permissionEvaluator"
);
assertThat
(
permissionEvaluator
)
.
isSameAs
(
this
.
context
.
getBean
(
PermissionEvaluator
.
class
));
}
@Test
public
void
testEnvironmentalOverrides
()
{
this
.
context
=
new
AnnotationConfigEmbeddedWebApplicationContext
();
...
...
@@ -610,4 +647,24 @@ public class OAuth2AutoConfigurationTests {
}
@Configuration
protected
static
class
RoleHierarchyConfiguration
{
@Bean
public
RoleHierarchy
roleHierarchy
()
{
return
mock
(
RoleHierarchy
.
class
);
}
}
@Configuration
protected
static
class
PermissionEvaluatorConfiguration
{
@Bean
public
PermissionEvaluator
permissionEvaluator
()
{
return
mock
(
PermissionEvaluator
.
class
);
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment